Nov 30

Stumpwm

Tag: basicoverdrive @ 9:56 pm

Stumpwm es un window manager minimalista, probablemente el mas minimalista de todos debido a que intenta ser lo mas configurable posible (incluyendo en tiempo real) manteniendo una apariencia visual minima. En Stumpwm no existen decoraciones de ventanas, tampoco iconos ni botones, y ningun fondo por defecto o degradado, simplemente la misma percepcion que se tiene de las X lanzadas ‘a pelo’. Simplemente se configura de forma personal mediante hooks y modificando algunos valores de variables.

Por cierto Stumpwm esta intimamente relacionado con emacs; primero porque esta integramente escrito en lisp y es configurable en tiempo real, evaluando las expresiones de algo que esta ejecutandose en dicho momento y modificando por tanto su codigo y datos. Y segunda porque tiene ciertos keybindings asociados directamente y por defecto a nuestro entorno favorito, emacs.

Stumpwm se puede interpretar de dos formas, o bien haciendo uso de clisp (Common Lisp) o sbcl (Steal Bank Common Lisp, dialecto de Lisp y variante de CL). Por defecto si usamos el apt de debian empleara clisp, aunque yo recomiendo encarecidamente usar sbcl, requerido por ejemplo para el uso de xinerama con pantalla extendida para doble monitor, como es mi caso (recordad que el uso de 2 pantallas aumenta la productividad de manera significativa, asi que esto es importante).

Si habeis tenido el error de meter clisp mediante apt-get y ahora quereis meter sbcl, debemos limpiar ciertos directorios que apt-get install –remove –purge no habra realizado. Como por ejemplo eliminar el contenido del directorio /var/cache/common-lisp-controller/.

# rm -Rf /var/cache/common-lisp-controler/*

Ademas desde hace un par de semanas hasta ahora, existe un conflicto (no confundir con bug) desde que estan siendo retirados algunos scripts lisp en debian, y deberemos substituir el script asdf que se encuentre en el source de stumpwm (en caso de que instalemos stumpwm desde git). Asi que primero nos disponemos a bajar la ultima version de stumpwm en desarrollo:

$ git clone git://git.savannah.nongnu.org/stumpwm.git

Una vez hecho esto entramos en el directorio creado que por defecto es stumpwm:

$ cd stumpwm

Este es un paso adicional requerido solo en caso de que persista el conflicto de asdf.el que trae stumpwm (eso solo se puede saber intentando instalar el asdf original que trae stumpwm mediante sbcl, en caso de dar error de compilacion en los pasos siguientes), en ese caso substituimos el script asdf.el que incluye nuestro paquete stumpwm por el asdf de la version de desarrollo, para ello primero renombramos el original:

$ mv asdf.el asdf.el.old

Y luego realizamos descarga de asdf (Another System Definition Format) en su version en desarrollo:

$ git clone http://common-lisp.net/project/asdf/asdf.git

Una vez hecho esto necesitamos instalar asdf, asi como otros scripts en nuestro sistema sbcl, para ello primero entramos en sbcl (Hacedlo desde el directorio stumpwm para no tener que jugar con rutas):
$ sbcl
Y luego realizamos la instalacion de asdf, clx y cl-ppcre (requeridos por stumpwm), notese que los «son parte del prompt de sbcl:
: (require :asdf)
: (require :asdf-install)
: (asdf-install:install :clx)
: (asdf-install:install :cl-ppcre)

Ahora ya podemos lanzar el configure para compilar

stumpwm usando sbcl:

$ ./configure –with-lisp=sbcl

Y Luego obviamente compilamos stumpwm (para ello se usara el compilador sbcl especificado anteriormente):

$ make

Para finalmente instalarlo en nuestro sistema:

$ make install

En caso de haber tenido exito, ya podemos modificar nuestro .xinitrc y anadir una linea tal que asi:

$ exec stumpwm &

Si todo ha ido bien, ya podremos disfrutar de nuestro flamante stumpwm, del cual explicare los keystrokes fundamentales para poder moverse con un minimo de soltura (todos ellos vendran precedidos por el prefijo C-t):

C-t ! Evalua una expresion
C-t e Lanza emacs
C-t ? Lanza la Ayuda
C-t : Muestra el prompt de Stumpwm
C-t ; Muestra el prompt de CL
C-t : quit Llama a la funcion quit de stumpwm
C-t ; (ext:quit) Evalua la funcion quit de clisp (dependiendo de como se haya compilado puede funcionar o no existir)
C-t ; (sb-ext:quit) Evalua la funcion quit de sbcl (dependiendo de como se haya compilado puede funcionar o no existir)
C-t TAB Mueve el foco al siguiente frame
C-t r <arriba/abajo/izq/der> Redimensiona un frame acortado por arriba/abajo/izq/der (requiere al menos 2 frames)

C-t <arriba/abajo/izq/der> Mueve el foco arriba/abajo/izq/der.
C-t t Iguala dimensiones de los frames
C-t Desplaza el foco a un n-frame determinado
C-t q Libera frames muertos
C-t C-t Cambia a otro frame (switch)
C-t M-<arriba/abajo/izq/der> Desplaza el frame a arriba/abajo/izq/der

C-t s Divide la aplicacion de forma horizontal
C-t S Divide la aplicacion de forma vertical
C-t Q Hace que la aplicacion ocupe toda la pantalla (C-t r de resize solo permitira hasta cierto margen debido a que cada vez que se ejecuto C-t s o C-t S se creo un nuevo frame por eso es necesario usar C-t Q).

Recordad que en emacs y elisp, un frame es lo que a lo en la actualidad nos referimos a ventana, y un a ventana es lo que en la actualidad nos referimos a frame, debido a razones historicas.

Para un listado completo de todos los keybindings asi como el resto de componentes y como se manejan en stumpwm buscad en el manual oficial de stumpwm.

Si quereis meter un fondo de pantalla al iniciar stump, podeis crear el fichero .stumpwmrc con el contenido:

(set-bg-color «black»)

O bien:

(run-shell-command «xsetbg ~/fondos/fichero.png»)

Con Xinerama activado para los dos monitores, en mi caso este es el resultado:

stumpwm al iniciar (captura reducida, haced click para ampliar a 3360×1050)

Free Image Hosting at www.ImageShack.us

stumpwm mostrando la ayuda (captura reducida, haced click para ampliar a 3360×1050)

Free Image Hosting at www.ImageShack.us

Tambien si quereis experimentar eso que decia de ‘programar y evaluar vuestro codigo en tiempo real’ sin miedo de perder las X y por tanto vuestro trabajo, con dos monitores es posible, es decir en el primero lanzariais stumpwm y alli abririais vuestro emacs. Independientemente lanzais Xnest y un nuevo servidor en :1 que muestre en una pantalla del servidor en :0, desde emacs lanzais stumpwm y lo conectais a :1, asi tendriais en una pantalla emacs y en la otra el windowmanager. Ahora aqui en emacs podeis ir modificando y evaluando codigo de stumpwm y viendo en tiempo real dichos cambios.

Por acabar una demo de stumpwm (aunque algo antigua [2007] pero de las pocas que he encontrado):

Troubleshooting

Solucion de algunos problemas que me han surgido con stumpwm:

En latex-mode y AucTeX combinandolo con stumpwm surge un conflicto entre keybindings, ya que C-t C-t en stumpwm hace toggle entre frames mientras que C-c C-t C-p en latex-mode con AucTeX sirve para invocar pdfLatex para especificar si la salida sera dvi o pdf. La forma de solucionarlo es empleando el comando de stumpwm C-t t, el cual generara un C-t que nos servira para poder usar el comando C-c C-t C-p en cualquier otro WM, pero que en este se realizara mediante C-c C-t t C-p.

2 Responses to “Stumpwm”

  1. GNU/Emacs » AUCTeX says:

    […] Existen algunos keystrokes que entran en conflicto con stumpwm (para mas informacion sobre este peculiar wm, ver mi articulo sobre stumpwm): […]

  2. GNU/Emacs » SBCL en emacs says:

    […] ANSI CL, tambien podriamos usar el propio SBCL para compilar SBCL. En su dia ya lo explicamos para usar stumpwm (que puede usar o bien CLISP o bien SBCL) aunque aqui lo usamos para un proposito diferente y […]

Leave a Reply

You must be logged in to post a comment.