dwm (Español)

From ArchWiki
The printable version is no longer supported and may have rendering errors. Please update your browser bookmarks and please use the default browser print function instead.

Tango-preferences-desktop-locale-modified.pngLa traducción de este artículo o sección no refleja el texto original.Tango-preferences-desktop-locale-modified.png

Motivos: Desactualizado. (Discusión en Talk: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

  1. 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.

Sugerencia: Si el directorio (~/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].

Nota: Asegúrese de realizar una copia de respaldo del archivo config.h, en caso de que algo no funcione correctamente.

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
Nota: Debe asegurarse de tener solamente una instancia de dwm en ~/.xinitrc o ~/.Xclients.

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