dwm (Español)
dwm es un gestor de ventanas dinámico para X. Permite posicionar las mismas en forma de mosaico (tiling), en forma de pila (stack), y en pantalla completa (monocle), así como en diversas modalidades adicionales mediante la ayuda de parches opcionales. La disposición de las ventanas puede ser aplicada en forma dinámica optimizando así el entorno en función de la aplicación en uso y la tarea a realizar. dwm es extremadamente liviano y rápido, está escrito en C con la premisa de que su código fuente no supere las 2000 líneas. Provee soporte de multi-monitor para xrandr y Xinerama.
Instalación
Estas instrucciones le indicarán como instalar dwm utilizando makepkg junto a al Arch Build System, o ABS. Ésto le permitirá modificar la configuración posteriormente sin complicaciones. Si solamente está interesado en probar dwm, puede simplemente instalar el paquete binario desde los repositorios:
# pacman -S dwm
Tenga en cuenta que al omitir compilar dwm desde su código fuente la personalización se verá truncada, ya que toda la configuración de dwm es realizada editando el código fuente. Teniendo ésto en cuenta, el resto del artículo asume que dwm ha sido compilado desde el código fuente como será explicado a continuación en ésta sección.
Quizá también quiera considerar instalar dmenu, un menú dinámico, rápido y liviano para X
- pacman -S dmenu
Requerimientos
Las herramientas básicas de programación presentes en el paquete base-devel son requeridas para compilar dwm y crear un paquete de éste, y el paquete de abs[enlace roto: package not found] también es un requisito para obtener los scripts de creación:
# pacman -S base-devel abs
Descarga de los scripts de creación con ABS
Una vez que los paquetes requeridos están instalados, utilize ABS para obtener los últimos scripts de creación desde los repositorios:
# abs community/dwm
Por último, copie los scripts de creación de dwm desde el árbol de directorios de ABS a un directorio temporal. Por ejemplo:
$ cp -r /var/abs/community/dwm ~/dwm
Creación e instalación del paquete
Use cd
para acceder al directorio que contiene los scripts de creación (en el ejemplo previo utilizamos ~/dwm
). Luego ejecute:
$ makepkg -i
Ésto compilará dwm, creará un paquete de Arch Linux conteniendo los archivos resultantes e instalará los paquetes, todo en un sólo paso. De ocurrir un problema durante éste proceso, verifique el mensaje mostrado por pantalla en busca de información relacionada.
~/dwm
) es conservado, puede ser utilizado posteriormente para realizar cambios en la configuración por defecto.Configuración
Como se mencionó anteriormente, dwm es configurado exclusivamente en tiempo de compilación mediante algunos de sus archvos de código fuente, siendo éstos config.h
y config.mk
. Si bien la configuración inicial es funcional, es lógico esperar que en algún momento los usuarios deseen realizar modificaciones y ajustes a sus configuraciones.
Método 1: Re-crear con ABS (recomendado)
Modificar la configuración de dwm es bastante sencillo utilizando éste procedimiento.
Personalizando config.h
Busque y diríjase al directorio que contiene el código fuente de dwm utilizado durante la instalación (~/dwm
en el ejemplo anterior). Dentro de ésta carpeta encontramos el archivo config.h
, en el cual se almacenan las preferencias generales de configuración de dwm. La mayoría de las opciones que encontramos dentro de éste archivo deberían ser auto-descriptivas, pese a que algunas no compartan el mismo rasgo. Para una información detallada de éstas opciones, visite el https://dwm.suckless.org/ sitio de dwm].
Una vez que realizamos los cambios , redirigimos el nuevo md5sums a PKGBUILD:
$ makepkg -g >> PKGBUILD
Ésto eliminará un error de comparación entre los checksum del archivo config.h
original y la copia modificada.
El paso siguiente es compilar y re-instalar:
$ makepkg -efi
Asumiendo que los cambios realizados en la configuración son válidos, éste comando compilará dwm, re-creará y re-instalará el paquete resultante. De ocurrir un problema durante éste proceso, verifique el mensaje mostrado por pantalla en busca de información relacionada.
Finalmente, reiniciamos dwm para aplicar los nuevos cambios.
Notas
De ahora en más, en vez de actualizar el md5sum para cada modificación del archivo config.h
, que es sabido que ocurre frecuentemente, simplemente se podría eliminar el arreglo (array) de md5sum y re-crear dwm con la opción --skipinteg
:
$ makepkg -efi --skipinteg
Luego de agregar unas líneas al script de inicio de dwm, es posible reiniciar dwm sin cerrar sesión y programas abiertos.
Método 2: Mercurial (avanzado)
dwm es mantenido mayoritariamente con una versión de control Mercurial en suckless.org[enlace roto 2020-08-02]. Aquellos ya familiarizados con Mercurial pueden encontrar conveniente mantener las configuraciones y los parches con éste sistema. En el sitio web oficial podemos encontrar un tutorial avanzado[enlace roto 2020-08-02] referido al tema.
Antes de crear dwm desde las fuentes Mercurial, asegúrese de modificar el archivo config.mk
adecuadamente, ya que un error en éste paso puede resultar en la caída del servidor X. Estos son los valores que necesitan ser modificados:
Modify PREFIX
:
PREFIX = /usr
The X11 include folder:
X11INC = /usr/include/X11
And the the X11 lib directory:
X11LIB = /usr/lib/X11
Iniciando dwm
Para iniciar dwm con startx
o con el gestor de inicio de sesión SLiM, simplemente agregue las siguientes líneas al archivo ~/.xinitrc
:
exec dwm
Si utiliza GDM, debe agregar la línea a ~/.Xclients
, y seleccionar "Run XClient Script" del menú Sessions.
Configuración de la barra de estado (statusbar)
dwm utiliza xsetroot -name
para mostrar información en su barra de estado (statusbar)
Barra de estado básica
Este ejemplo indica como mostrar la fecha en formato ISO 8601. Debemos agregar a ~/.xinitrc
or ~/.Xclients
las siguientes líneas:
while true; do xsetroot -name "$( date +"%F %R" )" sleep 1m # Update time every minute done & exec dwm
Este ejemplo está pensado para las computadoras portátiles que dependen del paquete acpi para mostrar información correspondiente a la batería:
while true ; do xsetroot -name "$( acpi -b | awk '{ print $3, $4 }' | tr -d ',' )" sleep 1m done & exec dwm
Éste script muestra la cantidad de batería restante, así como de su estado de carga mediante el comando awk para recortar el texto innecesarios de acpi y tr para eliminar las comas.
Una alternativa al script anterior es mostrar el estado de la batería de forma selectiva, en función del estado actual de carga:
while sleep 1m; do batt=`LC_ALL=C acpi -b` case $batt in *Discharging*) batt=${batt_main#* * * }; batt="${batt%%, *} " ;; *) batt= ;; esac xsetroot -name "$batt`date +"%R"`" done & exec dwm
Barra de estado con conky
Disponible en AUR, conky-cliAUR es una versión especial de conky que imprime la información a stdout
. Si ya se encuentra acostumbrado a conky, puede crear una barra de estado con abundante información en cuestión de minutos. Una vez que conky ha sido confiugrado a gusto, simplemente imprima el resultado redirigiendo conky a la barra de estado con xsetroot -name
:
conky | while read -r; do xsetroot -name "$REPLY"; done & exec dwm
El siguiente ejemplo de .conkyrc
muestra diversa información de una computadora con doble núcleo:
background no out_to_console yes update_interval 2 total_run_times 0 use_spacer none TEXT $mpd_smart :: ${cpu cpu1}% / ${cpu cpu2}% ${loadavg 1} ${loadavg 2 3} :: ${acpitemp}c :: $memperc% ($mem) :: ${downspeed eth0}K/s ${upspeed eth0}K/s :: ${time %a %b %d %I:%M%P}
Es posible también utilizar la versión estándar de conky agregando la opción out to x no
a la configuración de .conkyrc
. En el anterior ejemplo se vería así:
background no out_to_x no out_to_console yes update_interval 2 total_run_times 0 use_spacer none TEXT $mpd_smart :: ${cpu cpu1}% / ${cpu cpu2}% ${loadavg 1} ${loadavg 2 3} :: ${acpitemp}c :: $memperc% ($mem) :: ${downspeed eth0}K/s ${upspeed eth0}K/s :: ${time %a %b %d %I:%M%P}
Uso extendido
Parches y modos de mosaico (tiling) adicionales
El sitio oficial tiene varios parches[enlace roto 2020-08-02] que pueden agregar funcionalidad adicional a dwm. Los usuarios pueden personalizar fácilmente dwm mediante la aplicación de las modificaciones que deseen. Por ejemplo, el parche Bottom Stack[enlace roto 2020-08-02] provee una forma de posicionamiento en mosaico adicional que divide la pantalla en forma horizontal, al contrario de la forma original, que lo hace verticalmente. Así mismo, Bottom Stack divide los mosaicos secundarios en forma horizonta.
El parche gaplessgrid[enlace roto 2020-08-02] permite que la división en mosaicos sea en forma de grilla.
Habilitar un posicionamiento (layout) diferente por cada tag
El comportamiento por defecto de dwm es aplicar el posicionamiento seleccionado a todos los tags en forma simultánea. Para tener diferentes posicionamientos en diferentes tags, debemos utilizar el partche pertag.
Eliminar espacios entre ventanas de las terminales
Si se ven espacios vacíos en el escritorio fuera de las ventanas de las terminales, probablemente se deba al tamaño de la fuente de la terminal. Para solucionar ésto, o bien puede ajustar el tamaño de la fuente hasta encontrar la escala ideal que elimina el hueco, o modificar resizehints
a False en el archivo config.h
:
static Bool resizehints = False; /* False means respect size hints in tiled resizals */
Ésto causará que dwm ignore las peticiones de ajuste de tamaño de todas las ventanas, no sólo de las terminales. La desventaja de esta solución es que algunas terminales pueden sufrir anomalías al ser re-dibujadas en pantalla, tales como líneas fantasma o saltos de líneas premators, entre otras.
Reiniciar dwm sin cerrar sesión y programas abiertos
Para reiniciar dwm sin cerrar sesión o cerrar los programas abiertos, modifique o agregue el siguiente código al script de inicio, así dwm carga en un bucle while, de la siguiente manera:
while true; do # Log stderror to a file dwm 2> ~/.dwm.log # No error logging #dwm >/dev/null 2>&1 done
Ahora dwm puede ser reiniciado sin cerrar súbitamente otras ventanas X utilizando la combinaciones de teclas correspondiente (Mod1+Shift+q
por defecto).
Es una buena idea poner el script anterior en un archivo separado, por ejemplo ~/bin/startdwm
, y ejecutarlo con ~/.xinitrc
. De ésta manera, cuando se desee reiniciar la sesión X, simplemente debe ejecutar killall startdwm
, o asignarlo a una tecla de su conveniencia.
Deshabilitar el ganar foco con el ratón (mouse)
Para deshabilitar la posibilidad de ganar foco utilizando el ratón, simplemente hay que comentar la siguiente línea en la definición de la estructura de control en dwm.c
:
[EnterNotify] = enternotify,
Recursos adicionales
- Sitio oficial de dwm[enlace roto 2020-08-02]
- dmenu - Lanzador de aplicaciones dinámico y simple de los desarrolladores de dwm
- Hilo de dwm en el foro
- Fondos de pantalla de dwm[enlace roto 2020-08-02] y el hilo del foro de fondos de pantalla de dwm (en inglés)
- HowTo por Snake[enlace roto 2021-05-11] (en inglés)
- Migrando a dwm[enlace roto 2020-08-02] (en inglés)