Copyright
Copyright © José
Luis Lara Carrascal 2007-2013 
Sumario
Introducción
Características
Formatos de archivo soportados
Preliminares
Instalación
Configuración
Iniciamos Deco
Usar Deco con los administradores de archivos
Paquetes binarios
Enlaces
Introducción
Siempre es bueno tener a mano un multiusos que nos facilite
la
tarea de extracción de todo tipo de paquetes (comprimidos o
no
comprimidos), y eso es lo que nos proporciona Deco.
En vez de tener que estar escribiendo el comando de extracción
de
turno en función del tipo de paquete que vayamos a extraer,
con
sólo escribir por ejemplo "deco archivo.tar.bz2"
o "deco archivo.rar",
éstos serán extraídos sin
ningún tipo de
problemas, y lo mejor, creando siempre un directorio del paquete
aún en el caso de que éste no hubiera sido
comprimido con
el mismo.
Muchos usuarios habrán comprobado muchas veces que
al ir a extraer un zip o
rar con sus comandos respectivos, los archivos aparecían
desperdigados en el directorio de extracción sin recrear el
directorio del paquete en cuestión, con Deco
se acabó todo esto, y además podemos editar a
nuestro antojo los comandos de extracción de los diferentes
tipos de archivos que soporta este programa.
Características
*
Permite evitar el borrado del archivo a extraer con la
opción -u
* Crea siempre un directorio de extracción
evitando la forma en que ha sido creado el archivo a extraer.
* Borra el contenido parcial de la extracción de
un archivo incompleto con la opción -c
* Con la opción -v muestra en
pantalla todo el proceso de extracción.
* Puede extraer archivos con extensión
desconocida. Ejemplo: deco
-e gz archivo
* En el caso de que exista un directorio extraído
del
mismo archivo, si volvemos a ejecutar el comando de
extracción, Deco
creará el mismo directorio con el prefijo 1-,2-, etc, evitando el
borrado del directorio anterior.
* Los comandos de extracción por defecto de los
diferentes tipos de archivo son editables mediante el archivo
correspondiente que se encuentra en /usr/local/share/deco.
Formatos de archivo soportados
| Extensión |
Software
Requerido |
| 7z |
7zr |
| a |
ar |
| ace |
unace |
| alz |
unalz |
| ape |
MAC.exe, wine |
| ar |
ver a
|
| arc |
arc |
| arj |
arj |
| ark |
ver arc
|
| bz2 |
bunzip2 |
| cab |
cabextract o unshield |
| cbr |
ver rar
|
| cbz |
ver zip
|
| cpio |
cpio |
| cpio.bz2 |
bzcat, cpio |
| cpio.gzip |
cpio, gzip | | cpio.lz | cpio, lzip |
| cpio.lzo |
cpio, lzop | | cpio.xz | cpio, xzcat |
| deb |
dpkg-deb |
| ear |
ver zip
|
| flac |
flac |
| gem |
rm, tar |
| gz |
gunzip |
| ipsw |
ver zip |
| jar |
ver zip
|
| lha |
lha |
| lrz |
lrunzip |
| lz |
lzip |
| lzh |
ver lha |
| lzma |
lzma/unlzma |
| lzo |
lzop |
| odc |
ver zip |
| odf |
ver zip |
| odg |
ver zip |
| odi |
ver zip |
| odm |
ver zip |
| odp |
ver zip |
| ods |
ver zip |
| odt |
ver zip |
| otc |
ver zip |
| otf |
ver zip |
| otg |
ver zip |
| oth |
ver zip |
| oti |
ver zip |
| otp |
ver zip |
| ots |
ver zip |
| ott |
ver zip |
| oxt |
ver zip |
| pk3 |
ver zip
|
| pk4 |
ver zip
|
| rar |
unrar |
| rpm |
bunzip2, rpm2cpio, cpio, dd, gunzip, rpmoffset |
| rz |
runzip |
| shn |
shorten |
| sue |
ver arc
|
| t7z |
ver tar.7z |
| tar |
tar |
| tar.7z |
7za, tar |
| tar.bz2 |
tar |
| tar.gz |
tar |
| tar.lrz |
lrunzip, rm, tar |
| tar.lz |
lzip, tar |
| tar.lzma |
lzma, tar o lzcat, tar |
| tar.rz |
rm, runzip, tar |
| tar.xz |
tar, unxz |
| tar.z |
ver tar.gz
|
| taz |
ver tar.gz
|
| tbz |
ver tar.bz2
|
| tgz |
ver tar.gz
|
| tlz |
lzma, tar o lzcat, tar o lzip, tar |
| txz |
ver tar.xz |
| udeb |
ver deb |
| wsz |
ver zip
|
| xpi |
ver zip
|
| xz |
unxz |
| z |
ver gz
|
| zip |
unzip |
| zoo |
zoo |
Preliminares
1) Comprobar que la ruta de instalación de los binarios del programa la tenemos en nuestro PATH
Abrimos una ventana de terminal y ejecutamos el siguiente comando,
[jose@Fedora-18 ~]$ echo $PATH
/usr/lib/qt-3.3/bin:/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin:/home/jose/bin
|
Si no aparece entre las rutas mostradas el directorio /usr/local/bin, abrimos un editor de texto y añadimos lo siguiente,
#!/bin/sh
export PATH=/usr/local/bin:$PATH |
Lo guardamos con el nombre variables.sh, y lo instalamos en /etc/profile.d.
$ su
# install -m755 variables.sh /etc/profile.d
|
Tenemos que cerrar el emulador de terminal y volverlo a abrir para que
la variable de entorno aplicada sea efectiva. Es conveniente guardar
una copia de este script para posteriores
instalaciones de nuestro sistema, teniendo en cuenta que es el que se
va a utilizar a partir de ahora en todos los manuales de esta web, para
establecer variables de entorno globales, excepto en aquellas que
sólo afectan al usuario, en las que se utilizará el
archivo de configuración personal, ~/.bashrc.
La ventaja de utilizar el directorio /etc/profile.d es que es común a todas las distribuciones y nos evita tener que editar otros archivos del sistema como por ejemplo, /etc/profile.
2) Desinstalar versiones anteriores del programa ubicadas en el directorio /usr
Aún en el caso de que la versión a compilar la vayamos a
instalar en el mismo directorio que la que proporciona la
distribución, siempre se debe desinstalar previamente la versión antigua, para evitar conflictos innecesarios.
Instalación
Dependencias
Herramientas de Compilación
Entre paréntesis la
versión con la que se ha compilado Deco
para la elaboración de este documento.
* GCC - (4.7.2) o Clang - (3.2)
* Make - (3.82)
Descarga
deco-1.6.3.tar.gz | deco-archive-1.6.tar.gz
Extracción 
| Información general sobre el uso de los comandos |
En los comandos largos, seleccionar el comando desde su comienzo, omitiendo el símbolo ($ o #) y el espacio que existe entre éste y el comando. Una vez lo hemos seleccionado, pegarlo con el botón central del ratón sobre la
línea de comandos de la terminal, y darle a intro o enter. El comando se queda grabado en el historial de bash, por lo que podemos buscarlo con las flechas arriba y abajo del teclado para poder utilizarlo posteriormente, hasta que desaparezca del historial, si no volvemos a ejecutarlo y utilizamos otros comandos.
La barra inclinada hacia la izquierda (\) que aparece al final de la línea de algunos comandos, sirve para cortar el comando y poder seguir escribiéndolo en la siguiente línea. Cuando seleccionamos un comando cortado, y lo pegamos en la línea de comandos, la línea o líneas siguientes al comando de inicio aparecerán con el símbolo inicial (>), que indica la continuación del comando introducido en la siguiente línea. Le damos a intro o enter, y éste se ejecutará sin ningún problema. En el historial de bash, el comando aparecerá todo junto,
sin saltos de línea.
Los comandos de bucle que empiezan por for y terminan en done, hay que seleccionarlos desde for hasta done inclusive. Y luego realizar la misma operación de copiado y pegado que se explica en el comienzo de esta nota de
información.
|
$ tar zxvf deco-1.6.3.tar.gz; tar zxvf deco-archive-1.6.tar.gz
$ cd deco-1.6.3
|
Optimizaciones
GCC
$ sed -i 's:-O2:-O3 -march=amdfam10 -mtune=amdfam10:' config.mk
|
Clang
$ sed -i 's:-O2:-O3 -march=amdfam10:' config.mk
|
| Donde pone amdfam10
se indica el procesador respectivo de cada sistema
seleccionándolo de la siguiente tabla: |
Nota informativa sobre las optimizaciones para GCC
|
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado.
* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.
* En versiones de GCC 3.2.x e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
|
Nota informativa sobre las optimizaciones para Clang
|
* La opción '-mtune=' no
está soportada por Clang.
* Los valores de color azul no son compatibles con Clang.
* Las filas con el fondo de color amarillo son valores exclusivos de Clang,
y por lo tanto, no son aplicables con GCC.
|
| Valores |
CPU |
| generic |
Produce un código
binario optimizado para la mayor parte de procesadores existentes.
Utilizar este valor si no sabemos el nombre del procesador que
tenemos en nuestro equipo. Este valor sólo es aplicable en
la opción '-mtune='. Esta opción está disponible a
partir de GCC 4.2.x. |
| i386 |
Intel i386.
|
| i486 |
Intel i486. |
| i586, pentium |
Intel Pentium sin soporte de instrucciones MMX. |
| pentium-mmx |
Intel PentiumMMX basado en Pentium con soporte de instrucciones MMX. |
| pentiumpro |
Intel PentiumPro. |
| i686 |
Produce un código binario optimizado para la mayor parte de
procesadores compatibles con la serie 80686 de Intel. Todos los actuales lo son. |
| pentium2 |
Intel Pentium2 basado en PentiumPro con soporte de instrucciones MMX. |
| pentium3, pentium3m |
Intel Pentium3 basado en PentiumPro con soporte de instrucciones MMX y SSE. |
| pentium-m |
Versión de bajo
consumo de Intel Pentium3 con soporte de instrucciones MMX, SSE y SSE2.
Utilizado por los portátiles Centrino. |
| pentium4, pentium4m |
Intel Pentium4 con soporte de instrucciones MMX, SSE y SSE2. |
| x86-64 |
Procesadores
AMD y compatibles con soporte de instrucciones x86-64, SSE2 y
extensiones
64-bit. |
| yonah |
Procesadores
basados en la microarquitectura de Pentium M, con soporte de
instrucciones MMX, SSE, SSE2 y SSE3. |
| prescott |
Versión mejorada de Intel Pentium4 con soporte de instrucciones MMX, SSE, SSE2 y SSE3. |
| nocona |
Versión mejorada de Intel Pentium4 con extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2 y SSE3. |
| core2 |
Intel Core2 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3 y
SSSE3. Esta opción está disponible a partir de GCC 4.3.x. |
| penryn |
Intel
Penryn con soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3 y SSE4.1. |
| corei7 |
Intel Core i7 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1 y SSE4.2. Soporta también los procesadores Intel
Core i3 e i5. Esta opción está disponible a partir
de GCC 4.6.x. |
| nehalem |
Procesadores
basados en la microarquitectura de procesador Nehalem de Intel. |
| westmere |
Procesadores
basados en la microarquitectura de procesador Westmere de Intel. |
| corei7-avx |
Intel Core i7 con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1, SSE4.2, AVX, AES y PCLMUL. Soporta también los
procesadores Intel Core i3 e i5. Esta opción está
disponible a partir de GCC 4.6.x. |
| core-avx-i |
Intel Core (ivyBridge) con
extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3,
SSSE3, SSE4.1, SSE4.2, AVX, AES, PCLMUL, FSGSBASE, RDRND y F16C. Esta opción está disponible a partir
de GCC 4.7.x. |
| core-avx2 |
Intel Core (Haswell). Esta opción está disponible a partir
de GCC 4.7.x. |
| atom |
Intel Atom con extensiones 64-bit y soporte de instrucciones MMX, SSE, SSE2, SSE3 y SSSE3. Esta opción está
disponible a partir de GCC 4.5.x. |
| k6 |
AMD K6 con soporte de instrucciones MMX. |
| k6-2, k6-3 |
Versiones mejoradas de AMD K6 con soporte de instrucciones MMX y 3DNow!. |
| athlon, athlon-tbird |
AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y SSE prefetch. |
| athlon4, athlon-xp, athlon-mp |
Versiones mejoradas de AMD Athlon con soporte de instrucciones MMX, 3DNow!, enhanced 3DNow! y full SSE. |
| k8, opteron, athlon64, athlon-fx |
Procesadores basados en
AMD K8 core con soporte de instrucciones x86-64 (MMX, SSE, SSE2,
3DNow!, enhanced 3DNow! y extensiones 64-bit). |
| k8-sse3, opteron-sse3, athlon64-sse3 |
Versiones mejoradas de
AMD K8 core con soporte de instrucciones SSE3. Esta opción
está disponible a partir de GCC 4.3.x. |
| amdfam10, barcelona |
Procesadores basados en
AMD Family 10h core con soporte de instrucciones x86-64 (MMX, SSE,
SSE2, SSE3, SSE4A, 3DNow!, enhanced 3DNow!, ABM y extensiones
64-bit). Esta opción está disponible a partir de GCC 4.3.x. |
| btver1 |
Procesadores basados en
AMD Family 14h core con soporte de instrucciones x86-64 (MMX, SSE,
SSE2, SSE3, SSE4A, CX16, ABM y extensiones 64-bit). Esta opción está disponible a partir
de GCC 4.6.x. |
| bdver1 |
Procesadores basados en
AMD Family 15h core con soporte de instrucciones x86-64 (FMA4, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE,
SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones
64-bit). Esta opción está disponible a partir
de GCC 4.7.x. |
| bdver2 |
Procesadores basados en
AMD Family 15h core con soporte de instrucciones x86-64 (BMI, TBM, F16C, FMA, LWP, AVX, XOP, LWP, AES, PCL_MUL, CX16, MMX, SSE,
SSE2, SSE3, SSE4A, SSSE3, SSE4.1, SSE4.2, ABM y extensiones
64-bit). Esta opción está disponible a partir
de GCC 4.7.x. |
| winchip-c6 |
IDT Winchip C6, que equivale a un i486 con soporte de instrucciones MMX. |
| winchip2 |
IDT Winchip2, que equivale a un i486 con soporte de instrucciones MMX y 3DNow!. |
| c3 |
Via C3 con soporte de instrucciones MMX y 3DNow!. |
| c3-2 |
Via C3-2 con soporte de instrucciones MMX y SSE. |
| geode |
AMD integrado con soporte de instrucciones MMX y 3DNow!. Esta opción está disponible a partir de GCC 4.3.x. |
| native |
Produce un código
binario optimizado para el procesador que tengamos en nuestro sistema,
siendo éste detectado utilizando la instrucción cpuid.
Procesadores antiguos pueden no ser detectados utilizando este valor.
Esta opción está disponible a
partir de GCC 4.2.x. |
Compilación con GCC
Compilación con Clang
Instalación
como root
$ su
# make install
# cd ../deco-archive-1.6
# make install |
Desinstalación
como root
1) MODO TRADICIONAL
En el directorio de compilación ejecutamos el siguiente comando como root:
2) MODO MANUALINUX
El principal inconveniente del comando anterior es
que
tenermos que tener el directorio de compilación en nuestro
sistema para poder desinstalar el programa. En algunos casos esto
supone muchos megas de espacio en disco. Con el paquete de scripts que
pongo a continuación logramos evitar
el único inconveniente que tiene la compilación
de
programas, y es el tema de la desinstalación de los mismos
sin
la necesidad de tener obligatoriamente una copia de las fuentes
compiladas.
deco-1.6.3-scripts.tar.gz
$ su
# tar zxvf deco-1.6.3-scripts.tar.gz
# cd deco-1.6.3-scripts
# ./Desinstalar_deco-1.6.3 |
Copia de Seguridad
como root
Con este otro script creamos una copia de seguridad de los binarios
compilados, recreando la estructura de directorios de los mismos en un
directorio de copias de seguridad (copibin)
que se crea en el directorio /var. Cuando se haya creado el paquete comprimido de
los binarios podemos copiarlo como usuario a nuestro home
y borrar el que ha creado el script de respaldo, teniendo en cuenta que si queremos
volver a restaurar la copia, tendremos que volver a copiarlo al lugar
donde se ha creado.
$ su
# tar zxvf deco-1.6.3-scripts.tar.gz
# cd deco-1.6.3-scripts
# ./Respaldar_deco-1.6.3 |
Restaurar la Copia de Seguridad
como root
Y con este otro script (que se copia de forma automática cuando
creamos la copia de respaldo del programa) restauramos la copia de
seguridad como root cuando resulte necesario.
$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_deco-1.6.3
|
Configuración de Deco
Además de los archivo soportados que trae por defecto podemos
crear nuestros propios comandos de extracción o modificar los
que vienen con el programa, basta editar los archivos de
configuración que se ubican en /usr/local/share/deco, un ejemplo con el formato edj, que es el que utilizan los archivos de los temas y fondos de escritorio de Enlightenment - E17.
Abrimos un editor de texto y añadimos lo siguiente:
#!/bin/sh
exec edje_decc "$1"
|
Lo guardamos con el nombre extract, y lo instalamos en /usr/local/share/deco/edj.
$ su
# mkdir -p /usr/local/share/deco/edj
# install -m755 extract /usr/local/share/deco/edj
|
Ahora sólo queda comprobar su funcionamiento, abriendo cualquier
archivo de este tipo, en este caso uno de los fondos de escritorio que
vienen por defecto con Enlightenment - E17.
[jose@localhost descargas]$ deco Ladybug.edj
Output Image: Ladybug/rock.png
Output Image: Ladybug/ladybug.png
Output Image: Ladybug/grass.png
Output Image: Ladybug/shadow.png
Output Source File: Ladybug/background.edc
Output Build Script: Ladybug/build.sh
*** CAUTION ***
Please check the build script for anything malicious before running it!
Ladybug/ |
Iniciamos Deco
A continuación algunos ejemplos de extracción y la comparativa con el comando original de extracción.
a) Archivos RAR
Comando Original
Comando Deco
b) Archivos ZIP
Comando Original
Comando Deco
También los podemos poner todos en un mismo comando de ejecución
$ deco archivo.rar archivo.zip
|
Si queremos que se muestre la información de lo que se está extrayendo añadimos la opción -v
$ deco -v archivo.rar archivo.zip
|
Si no conocemos la extensión del archivo forzamos al programa de
extracción a extraerlo con la siguiente opción
$ deco -e EXT zip archivo
|
El añadido EXT es para que no tenga problemas en la extracción de los archivos con nombres largos.
Normalmente cuando extraemos un archivo comprimido en gz, el archivo comprimido se borra, Deco
siempre evita borrar el archivo (o archivos si está dividido en
varias partes como sucede con otros formatos) comprimido. Si aún
así queremos borrarlo ejecutar siempre el programa con la
opción -u
Comando Original
Comando Deco
Comando Deco con borrado del archivo comprimido
Usar Deco con los administradores de archivos
En Deco
no tenemos sólo una excelente utilidad de línea de
comandos, sino que también lo podemos utilizar cómo
aplicación auxiliar de los administradores de archivos, a la
hora de extraer los archivos comprimidos que deseemos. Sólo
tendremos que asociar las correspondientes extensiones de archivo al
comando de extracción de Deco, comando que tendrá que ir acompañado del parámetro -a para evitar que Deco
extraiga el archivo en cuestión en el directorio raíz del
usuario y no en el que esté ubicado el mismo. En el único
administrador de archivos, que no es necesario añadir este
parámetro, es en Xplorer.
Al carecer de IGU, la velocidad de extracción de Deco
es muy superior a cualquier otra aplicación semejante. A
continuación pongo algunos ejemplos de configuración de
algunos de los administradores de archivos que están
documentados en esta web.
1) PCManFM
En este caso y que es el modo habitual de la mayoría de
administradores de archivos, hacemos clic con el botón derecho
del ratón sobre el archivo en cuestión y seleccionamos Abrir con ... >> Abrir con otro programa. Nos saldrá una ventana de diálogo en la que escribiremos el comando deco -a en el apartado Command Line y marcaremos la opción Configurar aplicación seleccionada a la acción por defecto, igual que aparece en la captura de pantalla.
Esta acción crea un archivo desktop en ~/.local/share/applications/deco-usercreated-1.desktop,
por si la queremos borrar para deshacer la acción y que no
aparezca en la lista de aplicaciones a elegir. Al crearse el archivo
desktop, no es necesario volver a escribir el comando para otro tipo de
archivos que queramos asociar a Deco,
sólo tendremos que realizar la misma operación anterior,
con la diferencia de que podremos buscar el programa (aparece como deco) en la pestaña Todas las aplicaciones y asociarlo al tipo de archivo que pretendamos configurar.
2) ROX-Filer
El procedimiento es similar al anterior, hacemos clic con
el botón derecho del ratón sobre un archivo comprimido y
seleccionamos Definir qué ejecutar..., nos saldrá la ventana de diálogo y la dejamos como aparece en la captura de pantalla, luego hacemos clic en Use Command y el programa quedará asociado a este formato de archivo.
Enlaces
http://hartlich.com/deco >> La web de Deco.
|