Copyright
Copyright © José
Luis Lara Carrascal 2007-2013 
Sumario
Introducción
Preliminares
Instalación
Traducción al Español
Iniciamos TreeSize
Enlaces
Introducción
Los usuarios de Windows conocerán de sobra la utilidad de análisis del tamaño de los directorios y archivos denominada TreeSize for Windows, pues bien en GNU/Linux no podía faltar un programa similar (tan similar que es un clon del programa de Windows)
que nos facilite la tarea de conocer el espacio del disco que ocupan
los directorios y archivos que tengamos en nuestro sistema para saber
que archivos o directorio podemos eliminar para ganar espacio en
nuestra partición GNU/Linux.
TreeSize for Unix es una interfaz gráfica del comando du escrita en GTK2 e idéntica al programa original, una excelente utilidad que todo usuario de GNU/Linux debe de tener instalada en su sistema y cuya instalación trataremos en este manual.
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) Comprobar que la variable de entorno 'XDG_DATA_DIRS' incluye el directorio /usr/local/share
Esta variable se aplica para que los archivos desktop
ubicados en un directorio específico del sistema puedan ser
leídos por los menús de entornos gráficos
como XFce 4, o
paneles como LXPanel o Fbpanel.
Este aspecto es bastante delicado porque cada distribución es un
mundo y lo mejor que podemos hacer es establecer una variable de
entorno global que incluya todos los directorios predefinidos del
sistema que incluyen archivos desktop, siempre y cuando el directorio /usr/local/share
no esté incluido por defecto en la distribución de turno.
Para saberlo basta abrir el menú de aplicaciones en cualquiera
de los programas antes comentados y comprobar que aparece la entrada
correspondiente a la aplicación tratada en este manual. Si no es
así, en el mismo archivo /etc/profile.d/variables.sh, añadimos lo que está en rojo:
#!/bin/sh
export PATH=/usr/local/bin:$PATH
export XDG_DATA_DIRS=/usr/share:/usr/local/share:$XDG_DATA_DIRS |
3) 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 TreeSize
para la elaboración de este documento.
* GCC - (4.7.2) o Clang - (3.2)
* Gawk - (4.0.2)
* M4 - (1.4.16)
* Make - (3.82)
* Automake - (1.13.1)
* Autoconf - (2.69)
* Gettext - (0.18.2)
* Pkg-config - (0.28)
Librerías
de Desarrollo
*
Xorg o XFree86 - (Xorg 7.7 / xorg-server 1.13.2)
* GTK+ - (2.24.15)
Aplicaciones
* Wget - (1.14) [1]
[1] Requerido para poder descargarnos los iconos del archivo desktop desde internet.
Descarga
treesize-0.54.1-src.tbz2
Optimizaciones
GCC
$ export
{CFLAGS,CXXFLAGS}='-O3 -march=amdfam10 -mtune=amdfam10'
|
Clang
$ export
{CFLAGS,CXXFLAGS}='-O3 -march=amdfam10'
|
| 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. |
Extracción y Configuració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 jxvf treesize-0.54.1-src.tbz2
$ cd treesize-0.54.1
$ export {CC,CXX}=clang
$ sed -e 's:AM_CONFIG_HEADER:AC_CONFIG_HEADERS:' -e '10d' -i configure.in
$ autoreconf -vif
$ ./configure --disable-dependency-tracking
|
Explicación de los
comandos
export {CC,CXX}=clang
:
Si vamos a compilar el paquete con Clang, establecemos
la correspondiente variable de entorno.
sed -e
's:AM_CONFIG_HEADER:AC_CONFIG_HEADERS:' -e '10d' -i configure.in
:
Soluciona dos errores que se producen al ejecutar el comando
'autoreconf -vif', relacionados con automake
1.13.x, en
concreto estos dos:
configure.in:5:
error: 'AM_CONFIG_HEADER': this macro is obsolete.
You should use the 'AC_CONFIG_HEADERS'
macro instead.
|
configure.in:10:
error: 'AM_PROG_CC_STDC': this macro is obsolete.
You should simply use the 'AC_PROG_CC'
macro instead.
|
--disable-dependency-tracking : Acelera
el tiempo de compilación.
Compilación
Instalación
como root
$ su
# make install-strip
# for i in /usr/local/share/icons/hicolor ; do \
install -dm755 $i/{16x16,24x24,32x32,48x48,64x64,128x128,256x256}/apps ; \
wget -c http://findicons.com/files/icons/302/aire/256/hard_disk.png \
-O $i/256x256/apps/treesize.png ; \
wget -c http://findicons.com/files/icons/302/aire/128/hard_disk.png \
-O $i/128x128/apps/treesize.png ; \
wget -c http://findicons.com/files/icons/302/aire/64/hard_disk.png \
-O $i/64x64/apps/treesize.png ; \
wget -c http://findicons.com/files/icons/302/aire/48/hard_disk.png \
-O $i/48x48/apps/treesize.png ; \
wget -c //http://findicons.com/files/icons/302/aire/32/hard_disk.png \
-O $i/32x32/apps/treesize.png ; \
wget -c http://findicons.com/files/icons/302/aire/24/hard_disk.png \
-O $i/24x24/apps/treesize.png ; \
wget -c http://findicons.com/files/icons/302/aire/16/hard_disk.png \
-O $i/16x16/apps/treesize.png ; \
gtk-update-icon-cache -t $i &> /dev/null ; \
done
|
Creación del archivo treesize.desktop
Para que TreeSize
sea detectado por los menús de entornos gráficos
como XFce 4 o
paneles como LXPanel o Fbpanel, abrimos un editor de texto y añadimos lo siguiente:
[Desktop
Entry]
Encoding=UTF-8
Name=TreeSize for Unix
GenericName=TreeSize for Unix
Comment=Un analizador de espacio en disco
Exec=treesize
TryExec=treesize
Icon=treesize
Categories=Application;System
Type=Application |
Lo guardamos con la codificación de caracteres UTF-8, y con el nombre treesize.desktop. Luego lo instalamos como root en /usr/local/share/applications.
La desinstalación y respaldo de este archivo viene incluida en
los scripts correspondientes proporcionados en este manual.
$ su
# install -dm755 /usr/local/share/applications
# install -m644 treesize.desktop /usr/local/share/applications
|
Desinstalación
como root
1)
MODO TRADICIONAL
En el directorio de compilación
ejecutamos el siguiente comando como root:
Este comando no desinstala todos los archivos
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.
treesize-0.54.1-scripts.tar.gz
$ su
# tar zxvf treesize-0.54.1-scripts.tar.gz
# cd treesize-0.54.1-scripts
# ./Desinstalar_treesize-0.54.1 |
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 treesize-0.54.1-scripts.tar.gz
# cd treesize-0.54.1-scripts
# ./Respaldar_treesize-0.54.1 |
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_treesize-0.54.1
|
Traducción al
Español
Descarga
TreeSize_es-ML0.run
Instalación
como root
$ su
# sh TreeSize_es-ML0.run |
Iniciamos TreeSize
Sólo nos
queda teclear en una terminal o en un lanzador el comando treesize,
y el programa aparecerá en la pantalla, también se puede
crear un script o entrada en el menú para que se inicie en un
directorio específico, por ejemplo en nuestro home.
Si no queremos que examine otros sistemas de archivos como las particiones Windows,
pulsar en el icono del disco duro y como se puede ver en la captura no
mostrará el análisis de estas particiones.
Enlaces
http://treesize.sourceforge.net >> La web de TreeSize for Unix.
http://www.jam-software.com/treesize_free >> La web de TreeSize for Windows.
|