Manualinux
http://www.nvu.com http://www.gimp.org InicioPresentaciónActualizacionesManualesDescargasNoticiasAgradecimientoEnlaces

Entornos GráficosAplicaciones

Administradores de SesionesAdministradores de VentanasEscritoriosUtilidades de Escritorio

Administradores de Ventanas - Fvwm

Administradores de Ventanas - Awesome




Administradores de Ventanas - Awesome




Copyright

Copyright © José Luis Lara Carrascal  2009-2024   http://manualinux.es



Sumario

Introducción
Características
Instalación
Directorio de configuración personal
Atajos de teclado y ratón de Awesome
Configuración
Añadir aplicaciones al inicio de Awesome
Configurar el inicio de Awesome
Iniciamos Awesome
Enlaces




Introducción  

Awesome
es un administrador de ventanas híbrido que intenta recoger lo mejor de las 2 formas de interpretar la manipulación y disposición de las ventanas, que hoy en día imperan en el siempre complicado mundo de los administradores de ventanas. Por un lado, el modo tradicional de ventanas flotantes a libre disposición del usuario, por otro lado, el hoy en día pujante modo mosaico en el que son las aplicaciones las que se adaptan a las ventanas, y no, las ventanas a las aplicaciones, haciendo un uso intensivo del teclado, con los inconvenientes heredados del hecho de que no todas las aplicaciones están diseñadas para funcionar de esta manera y otras carencias ya explicadas en otros manuales publicados en esta web.

A partir de la versión 4.0, el programa ha sufrido un cambio radical en el aspecto de las ventanas, introduciendo decoración y botones al igual que los administradores de ventanas tradicionales, facilitando la alternancia entre el modo mosaico y el flotante, y haciendo el programa bastante más amigable para los usuarios de lo que lo era hasta esta versión.



Características    

* El primer administrador de ventanas que utiliza la librería asíncrona, XCB, en lugar de la antigua síncrona, XLib.
* No necesita ratón, todo se puede manejar con el teclado.
* Uso de etiquetas en lugar de escritorios virtuales, permite poner a los clientes en varias etiquetas y desplegarlas al mismo tiempo.
* Uso de diseños para organizar las ventanas en función del espacio disponible en la pantalla. Pueden ser: en mosaico (tiled), compuesto por una zona maestra y una zona apilable. La zona maestra contiene las ventanas que requieren más atención por parte del usuario y la zona apilable, las otras ventanas. La zona maestra puede dividirse en columnas y filas. Y diseño flotante, en el que el administrador de ventanas, gestiona éstas al modo tradicional, permitiendo al usuario, la libre disposición de las mismas en la pantalla.
* No distingue entre capas, ya sea flotante o en mosaico.
* Si los clientes de la pestaña(s) actualmente seleccionada están o no, en el diseño en mosaico, se pueden reordenar al vuelo. Las emergentes y las ventanas de tamaño fijo se convertirán automáticamente en ventanas flotantes.
* Manejo del diseño: Manejo automático de la ubicación de las ventanas según la política escogida para cada etiqueta.
* Soporte de transparencia real mediante el uso de xcomprmgr y la extensión Composite de Xorg.



Instalación  

Dependencias

Herramientas de Compilación  


Entre paréntesis la versión con la que se ha compilado Awesome para la elaboración de este documento.

* GCC - (14.1.0) o Clang - (18.1.8)
* CMake - (3.29.6)
* Ninja - (1.12.1)
* LuaRocks - (3.11.1)
* LGI - (0.9.2-git)
* Busted - (2.2.0)
* Luacheck - (1.2.0)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* Xorg - (7.7 / xorg-server 21.1.13)
   LibX11 - (1.8.9)
   Libxcb - (1.17.0)
* Cairo - (1.18.0)
* D-Bus - (1.14.10)
* Gdk-Pixbuf - (2.42.12)
* GLib - (2.74.7)
* Imlib2 - (1.12.2)
* Libev - (4.33)
* Libxdg-basedir - (1.2.3)
* Lua - (5.4.6)
* Pango - (1.54.0)
* Startup-Notification - (0.12)
* Xcb-util - (0.4.1)
* Xcb-util-cursor - (0.1.5)
* Xcb-util-image - (0.4.1)
* Xcb-util-keysyms - (0.4.1)
* Xcb-util-wm - (0.4.1)
* Xcb-util-xrm - (1.3)

Aplicaciones

* Asciidoctor - (2.0.23) - opcional [1]
* LDoc - (1.5.0) - opcional [2]
* ImageMagick - (7.1.1-33)

[1] Requerido para poder generar las páginas de manual del programa.
[2] Requerido para poder generar la documentación de Lua referida a Awesome.



Descarga

awesome-4.3.tar.xz  |  awesome_lua-5.3.diff

Optimizaciones

$ export {C,CXX}FLAGS='-O3 -march=znver3 -mtune=znver3'

Donde pone znver3 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 e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
Nota informativa sobre las optimizaciones para Clang
* La opción '-mtune=' está soportada a partir de la versión 3.4 de 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
Genéricos
Intel
AMD

Optimizaciones adicionales

Optimizaciones adicionales
GCC
Graphite
$ export {C,CXX}FLAGS+=' -ftree-loop-linear -floop-strip-mine -floop-block'
IPA
$ export {C,CXX}FLAGS+=' -fipa-pta'
LTO
$ export {C,CXX}FLAGS+=' -fuse-linker-plugin -flto=auto'
En versiones inferiores a GCC 10, sustituir auto por el número de núcleos que tenga nuestro procesador. Si sólo tiene uno, utilizar el parámetro -flto
PGO
1) Fase inicial de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -fprofile-generate=/var/pgo/awesome'
Configurar el paquete con las opciones siguientes: -DCMAKE_BUILD_TYPE=Debug
2) Ejecución y testeo del programa.
3) Fase final de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -fprofile-use=/var/pgo/awesome'
Clang
Polly
$ export {C,CXX}FLAGS+=' -O3 -mllvm -polly -mllvm -polly-vectorizer=stripmine'
LTO
$ export {C,CXX}FLAGS+=' -flto'
ThinLTO
$ export {C,CXX}FLAGS+=' -flto=thin'
La aplicación de esta optimización es alternativa a la tradicional LTO, a partir de Clang 3.9 y, por lo tanto, no es combinable con la misma.
Unified LTO
LTO >> ThinLTO
$ export {C,CXX}FLAGS+=' -flto -funified-lto'
$ export LDFLAGS+=' -Wl,--lto=thin'
ThinLTO >> LTO
$ export {C,CXX}FLAGS+=' -flto=thin -funified-lto'
$ export LDFLAGS+=' -Wl,--lto=full'
La aplicación de esta optimización es aplicable, a partir de Clang 17, y sólo es combinable con LLD.
PGO
1) Fase inicial de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -fprofile-generate=/var/pgo/awesome'
Configurar el paquete con las opciones siguientes: -DCMAKE_BUILD_TYPE=Debug
2) Ejecución y testeo del programa.
3) Conversión del perfil de optimización a un formato legible por Clang.
$ PGODIR=/var/pgo/awesome; llvm-profdata merge $PGODIR/default_*.profraw --output=$PGODIR/default.profdata
4) Fase final de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -fprofile-use=/var/pgo/awesome'

Parámetros adicionales

Establecer la ruta de búsqueda de directorios de librerías en sistemas de 64 bits multiarquitectura
$ export LDFLAGS+=" -L/usr/lib64 -L/usr/local/lib64 -L/opt/gcc14/lib64"
Cada usuario tendrá que establecer la ruta de búsqueda de directorios, en función de la distribución que utilice.

Parámetros adicionales de eliminación de errores específicos en el proceso de compilación
GCC 10 y Clang 11, y versiones superiores de los dos compiladores
$ export {C,CXX}FLAGS+=' -fcommon'

Establecer el uso de enlazador dinámico para Mold
$ export LDFLAGS+=' -fuse-ld=mold'

Establecer el uso de enlazador dinámico para LLD
Clang
$ export LDFLAGS+=' -fuse-ld=lld'
Optimizaciones complementarias LTO/ThinLTO/PGO de LLD
$ export LDFLAGS+=' -Wl,--lto-aa-pipeline=globals-aa -Wl,--lto-newpm-passes=pgo-memop-opt'
Optimizaciones complementarias LTO de LLD
$ export LDFLAGS+=" -Wl,--lto-partitions=$(expr $(nproc) / 2)"
Optimizaciones complementarias ThinLTO de LLD
$ export LDFLAGS+=" -Wl,--thinlto-jobs=$(expr $(nproc) / 2)"

Establecer la variable de entorno de uso de compilador para Clang
$ export CC=clang CXX=clang++

Extracción y Configuración  Bloc de Notas Información general sobre el uso de los comandos

$ tar Jxvf awesome-4.3.tar.xz
$ cd awesome-4.3
$ patch -Np1 -i ../awesome_lua-5.3.diff
$ cmake -S . -B build -DCMAKE_INSTALL_PREFIX=/usr -DSYSCONFDIR=/etc \
-DAWESOME_DOC_PATH=/usr/share/doc/awesome -DAWESOME_MAN_PATH=/usr/share/man \
-DAWESOME_XSESSION_PATH=/usr/share/xsessions -G Ninja

Explicación de los comandos

patch -Np1 -i ../awesome_lua-5.3.diff : Aplicamos este parche personal derivado de la modificación de código de la versión git del programa, que permite compilar el paquete con la versión 5.3 de Lua y superiores, añadiendo como nueva dependencia del mismo el gestor de paquetes de Lua, LuaRocks, para poder detectar correctamente el programa LGI.

-S . -B build : Establece el directorio del código fuente y crea de forma automática el directorio de compilación.

-DCMAKE_INSTALL_PREFIX=/usr : Instala el programa en el directorio principal, /usr.

-DSYSCONFDIR=/etc
: Instala el archivo de configuración en /etc/xdg/awesome, en lugar de /usr/etc/xdg/awesome.

-DAWESOME_DOC_PATH=/usr/share/doc/awesome : Instala la documentación del programa en /usr/share/doc/awesome, en lugar de /usr/local/share/doc/awesome.

-DAWESOME_MAN_PATH=/usr/share/man
: Instala las páginas de manual del programa en /usr/share/man, en lugar de /usr/local/share/man.

-DAWESOME_XSESSION_PATH=/usr/share/xsessions : Instala el archivo desktop requerido por los administradores de sesiones en /usr/share/xsession, en lugar de /usr/local/share/xsession.

-G Ninja : Utiliza Ninja en lugar de GNU Make para compilar el paquete (opcional).

Compilación

$ ninja

Parámetros de compilación opcionales

-v : Muestra más información en el proceso de compilación.

-j$(nproc) : Establece el número de procesos de compilación en paralelo, en función del número de núcleos e hilos que tenga nuestro procesador, tomando como referencia la información mostrada por el sistema con el comando correspondiente. Si nuestro procesador es mononúcleo de un solo hilo, no añadir esta opción.

Instalación como root

$ su -c "ninja install/strip"

Instalación del archivo de configuración personal en nuestro home

$ cp -rf /etc/xdg/awesome ~/.config

Borrar las páginas de manual adicionales instaladas con la utilidad BleachBit

$ su -c "bleachbit -c system.localizations"

Estadísticas de Compilación e Instalación de Awesome

Estadísticas de Compilación e Instalación de Awesome
CPU AMD Ryzen 5 5500
MHz 3600 (BoostMax=4457)
RAM 32 GB
Sistema de archivos XFS
Versión del Kernel 6.9.6-ml SMP PREEMPT_DYNAMIC x86_64
Modo de frecuencia de la CPU powersave (balance performance)
Planificador de CPU BMQ
Versión de Glibc 2.39
Enlazador dinámico LLD 18.1.8
Compilador Clang 18.1.8
Parámetros de optimización -03 -march=znver3 -mtune=znver3 -mllvm -polly -mllvm -polly-vectorizer=stripmine -flto -funified-lto -Wl,--lto=thin -Wl,--thinlto-jobs=6 -fprofile-use=/var/pgo/awesome -Wl,--lto-aa-pipeline=globals-aa -Wl,--lto-newpm-passes=pgo-memop-opt
Parámetros de compilación -v -j12
Tiempo de compilación 12"
Archivos instalados 596
Mostrar/Ocultar la lista de archivos instalados
Ocupación de espacio en disco 10,3 MB

Consumo inicial de CPU y RAM de Awesome

Consumo inicial de CPU y RAM de Awesome
Programa
CPU RAM
awesome 0 % 25,5 MB
Para medir el consumo de CPU se utiliza el programa top, y para medir el consumo de RAM se utiliza el script de Python, ps_mem.py, creado por Pádraig Brady, que podemos encontrar en este enlace.

Directorio de configuración personal  

~/.config/awesome Es el directorio de configuración personal de Awesome en nuestro home
~/.config/awesome/rc.lua Es el archivo de configuración personal de Awesome

Desinstalación como root

1) MODO TRADICIONAL

Este programa no tiene soporte para desinstalación con el comando 'ninja uninstall'   

2) MODO MANUALINUX

El principal inconveniente del comando anterior es que tenemos 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.

awesome-4.3-scripts.tar.gz

$ su
# tar zxvf awesome-4.3-scripts.tar.gz
# cd awesome-4.3-scripts
# ./Desinstalar_awesome-4.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 awesome-4.3-scripts.tar.gz
# cd awesome-4.3-scripts
# ./Respaldar_awesome-4.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_awesome-4.3



Atajos de teclado y ratón de Awesome  

Control del administrador de ventanas
Combinación de teclas Acción a realizar
Ctrl + Win + R Reinicia el programa
Win + Mayús + Q Termina el programa
Win + R Ejecuta el prompt
Win + X Ejecuta el prompt del código de Lua
Win + Retorno Despliega el emulador de terminal
Win + W Abre el menú principal
Ventanas de las aplicaciones clientes
Win + Mayús + R Redibuja la ventana enfocada
Win + M Maximiza la ventana
Win + F Pone la ventana a pantalla completa
Win + Mayús + C Mata la ventana enfocada
Win + T Etiqueta la ventana
Navegación 
Win + J Enfoca la siguiente ventana
Win + K Enfoca la ventana anterior
Win + U Enfoca la primera ventana urgente
Win + Flecha izquierda Ver la etiqueta anterior 
Win + Flecha derecha Ver la siguiente etiqueta
Win + 1-9 Conmuta a la etiqueta 1-9
Ctrl + Win + J Enfoca la siguiente pantalla (si tenemos más de un monitor conectado)
Ctrl + Win + K Enfoca la pantalla anterior (si tenemos más de un monitor conectado)
Win + Esc Enfoca la anterior etiqueta seleccionada
Modificación de la disposición de las ventanas
Win + Mayús + J Intercambia la aplicación cliente con la siguiente aplicación cliente
Win + Mayús + K Intercambia la aplicación cliente con la anterior aplicación cliente
Win + O Envía la aplicación cliente a la siguiente pantalla
Win + H Decrementa la anchura de la ventana maestra en un 5 %
Win + L Incrementa la anchura de la ventana maestra en un 5 %
Win + Mayús + H Incrementa el número de ventanas maestras en 1
Win + Mayús + L Decrementa el número de ventanas maestras en 1
Ctrl + Win + H Incrementa el número de columnas de las ventanas no-maestras en 1
Ctrl + Win + L Decrementa el número de columnas de las ventanas no-maestras en 1
Win + Espacio Cambia al siguiente diseño
Win + Mayús + Espacio Cambia al diseño anterior
Ctrl + Win + Espacio Activa el estado flotante de la aplicación cliente de la ventana
Ctrl + Win + Retorno Intercambia la ventana enfocada con la ventana maestra
Ctrl + Mayús + 1-9 Agrupa la ventana cliente con etiqueta
Ctrl + Win + Mayús + 1-9 Activa la etiqueta en la ventana cliente
Win + Mayús + F1-9 Agrupa las ventanas clientes marcadas con una etiqueta

Atajos del ratón
Combinación de teclas Acción a realizar
Navegación
Botón izquierdo en el nombre de la etiqueta Ver la etiqueta
Rueda del ratón en el nombre de la etiqueta Conmuta entre la etiqueta anterior y la siguiente
Rueda del ratón en la ventana raíz Conmuta entre la etiqueta anterior y la siguiente
Botón izquierdo, o botón derecho, o la rueda del ratón en el símbolo del diseño Conmuta entre el diseño anterior y el siguiente
Modificación de la disposición de las ventanas
Win + botón izquierdo en el nombre de la etiqueta Agrupa la aplicación cliente actual con sólo esta etiqueta
Win + botón derecho en el nombre de la etiqueta Activa esta etiqueta para la aplicación cliente
Botón derecho en el nombre de la etiqueta Añade esta etiqueta a la vista actual
Win + botón izquierdo en la ventana cliente Mueve la ventana
Win + botón derecho en la ventana cliente Redimensiona la ventana


 
Configuración  

La configuración de Awesome se realiza mediante la edición del archivo ~/.config/awesome/rc.lua, y que a continuación voy a clarificar un poco sin entrar en todas las posibilidades que ofrece dicho archivo.

1) Temas

El tema que trae por defecto es bastante pobre, tampoco es que Awesome destaque mucho en este apartado, pero si elegimos uno de los otros tres temas disponibles, quizá logremos darle un poquito de alegría a este oscuro administrador de ventanas. 

Línea 46
-- {{{ Variable definitions
-- Themes define colours, icons, font and wallpapers.
beautiful.init(awful.util.get_themes_dir() .. "sky/theme.lua")

Si tenemos pensado utilizar temas personalizados, procurar dejar la línea editada de la siguiente forma en lo que concierne a la ruta al archivo de configuración del tema, porque si no es así, resultará imposible cargarlos.

-- {{{ Variable definitions
-- Themes define colours, icons, font and wallpapers.
beautiful.init("~/.config/awesome/themes/sky/theme.lua")

2) Emulador de terminal y editor de texto por defecto

En el siguiente apartado definimos el emulador de terminal y el editor de texto predefinido que se ejecutarán mediante los correspondiente atajos de teclado predefinidos en el programa. En mi caso particular lo dejo así:

Línea 50
-- This is used later as the default terminal and editor to run.
terminal = "mrxvt"
editor = "leafpad"
editor_cmd = terminal .. " -e " .. mcedit

3) Tecla comodín predefinida para los atajos de teclado

Esto mejor no tocarlo, si no queremos tener problemas en el uso de atajos de teclado en las aplicaciones, define la tecla comodín que se utilizará para los atajos de teclado de Awesome, la predefinida es la tecla Windows, Mod4 en el archivo de configuración. 

Línea 55
-- Default modkey.
-- Usually, Mod4 is the key with a logo between Control and Alt.
-- If you do not like this or do not have such a key,
-- I suggest you to remap Mod4 to another key using xmodmap or other tools.
-- However, you can use another modifier like Mod1, but it may interact with others.
modkey = "Mod4"

4) Qué aplicaciones se ejecutarán en ventanas flotantes de forma predefinida

Pues todas aquellas que guarden la posición y el tamaño de la ventana al cerrarse, y las que tengan un tamaño de ventana fijo que no permita redimensionarlas en su totalidad. Es decir, todas aquellas que den problemas trabajando en modo mosaico y cuyo tamaño sea desproporcionado al habitual trabajando en un administrador de ventanas tradicional. Éste es el apartado más importante de la configuración de Awesome, ya que mediante el uso de xprop tendremos que ir definiendo aquellas aplicaciones que no queremos que sean encajonadas en un mosaico y poder ejecutarlas de manera "normal". También podemos configurar las que son de línea de comandos, que se realiza mediante instancia, a través del emulador de terminal predefinido. Un ejemplo con SMPlayer (muy recomendable hacer todo esto desde nuestro entorno gráfico habitual):

Necesitaremos la utilidad xprop para poder identificar el parámetro WM_CLASS (STRING), ejecutamos SMPlayer, abrimos una ventana de terminal y ejecutamos en la misma el comando 'xprop | grep WM_CLASS', el puntero del ratón se convertirá en una cruceta y con la misma hacemos clic sobre la ventana de SMPlayer, de la información que se muestre en la ventana de terminal, nos tenemos que quedar siempre con el valor que está en rojo.

[jose@localhost ~]$ xprop | grep WM_CLASS
WM_CLASS(STRING) = "smplayer", "Smplayer"

Luego lo añadimos justo detrás de las que ya están configuradas, con el siguiente parámetro,

    { rule = { class = "Smplayer" },
      properties = { floating = true } },

Línea 444
-- {{{ Rules
-- Rules to apply to new clients (through the "manage" signal).
awful.rules.rules = {
    -- All clients will match this rule.
    { rule = { },
      properties = { border_width = beautiful.border_width,
                     border_color = beautiful.border_normal,
                     focus = awful.client.focus.filter,
                     raise = true,
                     keys = clientkeys,
                     buttons = clientbuttons,
                     screen = awful.screen.preferred,
                     placement = awful.placement.no_overlap+awful.placement.no_offscreen
     }
    },

    -- Floating clients.
    { rule_any = {
        instance = {
          "DTA",  -- Firefox addon DownThemAll.
          "copyq",  -- Includes session name in class.
        },
        class = {
          "Arandr",
          "Gpick",
          "Kruler",
          "MessageWin",  -- kalarm.
          "Sxiv",
          "Wpa_gui",
          "pinentry",
          "veromix",
          "xtightvncviewer"},

        name = {
          "Event Tester",  -- xev.
        },
        role = {
          "AlarmWindow",  -- Thunderbird's calendar.
          "pop-up",       -- e.g. Google Chrome's (detached) Developer Tools.
        }
      }, properties = { floating = true }},

    -- Add titlebars to normal clients and dialogs
    { rule_any = {type = { "normal", "dialog" }
      }, properties = { titlebars_enabled = true }
    },

    { rule = { class = "Smplayer" },
      properties = { floating = true } },


5) Qué aplicaciones se ejecutarán de forma predefinida en una etiqueta determinada

Si queremos lanzar las aplicaciones en una etiqueta determinada, por ejemplo la 2 (tag = tags[1][2]), tendremos que utilizar también la utilidad xprop, al igual que hemos hecho en la sección anterior. Desde la versión 3.4 esto se ha incluido dentro de la sección anterior y su configuración, al igual que la de esa sección se ha vuelto más compleja. Si tenemos más de un monitor, y queremos lanzar la aplicación en una de las etiquetas del segundo monitor, tendremos que modificar el primer parámetro, por ejemplo: (tag = tags[2][4]), lanzaría la aplicación en la cuarta etiqueta del segundo monitor.

Línea 496
    -- Set Firefox to always map on tags number 2 of screen 1.
    { rule = { class = "Firefox" },
      properties = { tag = tags[1][2] } },
}
 }}}

6) Definir el número de etiquetas por defecto

En este apartado podemos limitar el número de etiquetas a utilizar como zonas de agrupamiento de ventanas, el equivalente en Awesome a los escritorios virtuales de un administrador de ventanas clásico. Por defecto es de 9, cambiando lo que está en rojo podemos aumentarlo o reducirlo. En el ejemplo lo he dejado en 6.

Línea 172
awful.screen.connect_for_each_screen(function(s)
    -- Wallpaper
    set_wallpaper(s)

    -- Each screen has its own tag table.
    awful.tag({ "1", "2", "3", "4", "5", "6" }, s, awful.layout.layouts[1])

7) Traducir el menú principal y añadir un menú personalizado de aplicaciones

Poco que traducir, la verdad.

Línea 83
-- {{{ Menu
-- Create a launcher widget and a main menu
myawesomemenu = {
   { "hotkeys", function() return false, hotkeys_popup.show_help end},
   { "manual", terminal .. " -e man awesome" },
   { "editar configuración", editor_cmd .. " " .. awesome.conffile },
   { "reiniciar", awesome.restart },
   { "salir", function() awesome.quit() end}
}

mymainmenu = awful.menu({ items = { { "awesome", myawesomemenu, beautiful.awesome_icon },
                                    { "abril terminal", terminal }
                                  }
                        })

Al igual que en el manual de QuarkWM, nos valdremos de la utilidad myGtkMenu, para proporcionarle a Awesome un menú muy superior en calidad a las opciones que nos ofrece su programador en el Wiki del programa, y por supuesto, mucho más fácil de editar. Simplemente tenemos que añadir la utilidad de atajos de teclado, XbindKeys, ya configurada para que active myGtkMenu, y cuya explicación extraigo del manual de QuarkWM.

El comando de ejecución de myGtkMenu lo añadimos al archivo de configuración de XbindKeys, ~/.xbindkeysrc, a partir de la línea 49, más o menos.

# specify a mouse button
"myGtkMenu ~/.myGtkMenu/Menu.txt"
Mod1+b:1
"claws-mail"
Mod1+s
"rox ~/"

Con esta configuración, cada vez que ejecutemos la combinación Alt + Clic izquierdo del ratón, el menú se desplegará en el lugar donde tengamos situado el puntero del ratón, con la importante ventaja, de que siempre se colocará por encima de cualquier aplicación que tengamos abierta.

Luego al final del archivo de configuración, ~/.config/awesome/rc.lua, añadimos el parámetro siguiente: os.execute("xbindkeys &")

client.add_signal("focus", function(c) c.border_color = beautiful.border_focus end)
client.add_signal("unfocus", function(c) c.border_color = beautiful.border_normal end)
-- }}}

os.execute("xbindkeys &")

8) Modificar el tamaño de las fuentes de texto de los temas de Awesome y el tamaño del menú de aplicaciones

Un tamaño de 8 píxeles para un monitor de alta resolución resulta terrorífico para los ojos de cualquiera, así que, si no queremos quedarnos ciegos, modificaremos el tamaño de las fuentes de texto y también el tamaño del menú de aplicaciones, para que se muestren de forma correcta las entradas correspondientes. Para no tocar los archivos del sistema, copiaremos los temas a nuestro directorio de configuración personal, y los editaremos uno a uno.

$ cp -rf /usr/share/awesome/themes ~/.config/awesome

En todos los archivos de configuración de los 4 temas (theme.lua), modificamos la siguiente línea de configuración, cambiando la fuente de texto y tamaño por la opción personal de cada uno. Un ejemplo:

-- BASICS
local theme = {}
theme.font          = "DejaVu Sans 10"


Y cambiamos la anchura y la altura del menú de aplicaciones, para que el texto del menú traducido nos quepa sin ningún problema. La altura es opcional al gusto de cada uno.

-- MISC
theme.wallpaper             = "/usr/share/awesome/themes/sky/sky-background.png"
theme.taglist_squares       = "true"
theme.titlebar_close_button = "true"
theme.menu_height           = 22
theme.menu_width            = 200


Guardamos los archivos y comprobamos que las fuentes de texto son las apropiadas para la resolución de pantalla que estamos utilizando.



Añadir aplicaciones al inicio  

Que nadie espere las posibilidades que ofrecen los administradores de ventanas normales, en Awesome, tendremos que conformarnos con aplicaciones de ventana normal o aplicaciones a ejecutar en 2º plano, nada de dockapps, barras de iconos, etc. El método es el mismo que el explicado anteriormente para el uso de myGtkMenu. Eso sí, podremos cargar un gestor de fondos como CWallpaper, para poder cambiar el fondo predefinido que traiga el tema de turno, o en su caso, cualquier comando de ejecución con los programas encargados de esta tarea (Esetroot, Hsetroot, etc), ampliamente tratados en esta web. Un ejemplo:

client.add_signal("focus", function(c) c.border_color = beautiful.border_focus end)
client.add_signal("unfocus", function(c) c.border_color = beautiful.border_normal end)
-- }}}

os.execute("xbindkeys &")
os.execute("cwallpaper -l &")
os.execute("rox &")
os.execute("xchat &")


 
Configurar el inicio de Awesome  

1) Para los que inician X desde terminal con el comando startx

Editamos el archivo ~/.xinitrc que se encuentra en nuestro home, si no existe lo creamos, y añadimos lo siguiente:
     
exec /usr/bin/awesome


2) XDM
 
Editamos el archivo ~/.xsession que se encuentra en nuestro home, si no existe lo creamos, y añadimos lo siguiente:

exec /usr/bin/awesome


3) GDM/LightDM/SDDM

El programa instala su propio archivo desktop en /usr/share/xsessions, por lo que el usuario no tiene que hacer nada.


4) Qingy

Abrimos un editor de texto y añadimos lo siguiente al mismo:

/usr/bin/awesome

Lo guardamos con el nombre Awesome, y lo instalamos en /etc/qingy/Xsessions.

$ su -c "install -m755 Awesome /etc/qingy/Xsessions"


5) SLiM

Primero editamos el archivo /etc/slim.conf y añadimos el nombre del entorno a la lista de los que tengamos en el sistema instalados, si queremos que sea el entorno que se inicie por defecto hay que colocarlo en el primer lugar de la lista.

# Sesiones disponibles (la primera es la predefinida).
# El actual nombre de sesión es reemplazado en el login_cmd
# anterior, para que su comando de acceso pueda manejar diferentes sesiones.
# vea el archivo xinitrc.ejemplo proporcionado con el código fuente de slim.

sessions            Fluxbox,WindowMaker,Blackbox,XFce4,E17,Awesome,IceWM,Openbox,ROX,Pekwm

Para finalizar editamos el archivo .xinitrc de nuestro home y añadimos la configuración del mismo, la variable DEFAULT_SESSION sobreescribe el entorno gráfico de inicio predefinido que pueda existir en el archivo /etc/slim.conf, permitiendo añadir el ejecutable de otro entorno que no esté configurado en el apartado anterior para ser iniciado por defecto, si queremos que sea Awesome, añadimos su script de ejecución, aunque si lo tenemos configurado el primero de la lista, esto no es necesario.

# La siguiente variable define la sesión que será iniciada si el usuario
# no elige de forma explícita una sesión
DEFAULT_SESSION=awesome


case $1 in
XFce4)
    exec startxfce4
    ;;
IceWM)
    exec icewm-session
    ;;
WindowMaker)
    exec wmaker
    ;;
Blackbox)
    exec startblackbox
    ;;
Fluxbox)
    exec startfluxbox
    ;;
E17)
    exec enlightenment_start
    ;;
Awesome)
    exec awesome
    ;;
Openbox)
    exec openbox-session
    ;;
Pekwm)
    exec pekwm
    ;;
ROX)
    exec rox-session
    ;;
AfterStep)
    exec afterstep
    ;;
*)
    exec $DEFAULT_SESSION
    ;;

esac

Con pulsar F1 ya podremos seleccionarlo de la lista e iniciarlo, si es el predefinido no es necesario seleccionarlo de la lista, se iniciará por defecto.



Iniciamos Awesome  


Captura Awesome - 1


Captura Awesome - 2


Captura Awesome - 3




Enlaces  


http://awesomewm.org >> La web de Awesome.


Foro Galería Blog


Actualizado el 22-06-2024

Administradores de Ventanas - Awesome

Administradores de Ventanas - Fvwm