b31f988833
Toda acción de escritorio converge en Desktop::apply(DesktopAction); el keymap era sólo un front-end. Esta tanda añade los otros tres. - DesktopAction::FocusWindow(WindowId): direccionamiento directo de una ventana (no sólo ciclar); si está en otro escritorio, salta a él. DesktopAction pasa a ser Serialize/Deserialize (postcard) además de Display/FromStr. - mirada-brain::ctl: el API de control externo. CtlRequest/CtlReply (marco postcard), CtlServer/CtlConn no bloqueantes y send_request. El Cerebro abre el socket y atiende en su bucle: la app mirada siempre, mirada-compositor sólo con el Cerebro embebido. - mirada-ctl: CLI de control estilo swaymsg/hyprctl — `mirada-ctl focus-next | focus-window 5 | workspace 3 | windows`. Parsea la acción de los argumentos vía FromStr. - HUD interactivo en la app mirada: pips de escritorio y ventanas del lienzo clicables (SwitchWorkspace / FocusWindow). - Ejemplo headless-ctl: un Cerebro sin gráficos para probar mirada-ctl en modo desatendido. Verificado end-to-end. mirada-brain: 29 -> 37 tests. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
114 lines
3.8 KiB
Markdown
114 lines
3.8 KiB
Markdown
# mirada-compositor — el Cuerpo de carmen
|
|
|
|
Un compositor Wayland teselante real, sobre [`smithay`]. Es el **Cuerpo**
|
|
de la arquitectura Cerebro↔Cuerpo de `mirada` (ver
|
|
`crates/modules/mirada/SDD.md`): habla el protocolo Wayland con los
|
|
clientes, compone sus superficies y aplica la geometría que decide el
|
|
Cerebro.
|
|
|
|
Backend `winit`: corre **anidado** — una ventana dentro de tu sesión
|
|
gráfica actual, X11 o Wayland. No toca DRM/KMS, así que es seguro de
|
|
arrancar sin dejar la sesión.
|
|
|
|
## Requisitos
|
|
|
|
Hace falta una **sesión gráfica anfitriona** (X11 o Wayland) donde
|
|
dibujar la ventana del compositor — es donde `winit` se anida. En un
|
|
servidor *headless* (SSH a una caja sin escritorio, `XDG_SESSION_TYPE=tty`,
|
|
sin `/dev/dri`) no hay dónde mostrar nada y el arranque aborta con un
|
|
mensaje que lo explica.
|
|
|
|
Para verlo en una caja headless: levanta un servidor X virtual y
|
|
conéctate por VNC.
|
|
|
|
```sh
|
|
Xvfb :99 -screen 0 1280x800x24 &
|
|
x11vnc -display :99 -localhost -nopw & # luego túnel SSH al :5900
|
|
DISPLAY=:99 cargo run -p mirada-compositor
|
|
```
|
|
|
|
El backend nativo DRM/KMS —que pintaría directo en la pantalla sin
|
|
sesión anfitriona— está pendiente (ver el SDD), y de todos modos
|
|
necesitaría un `/dev/dri`.
|
|
|
|
## Dos modos
|
|
|
|
- **Autónomo** (por defecto) — lleva un `Desktop` (de `mirada-brain`)
|
|
embebido. Es un compositor teselante completo en un solo proceso.
|
|
|
|
```sh
|
|
cargo run -p mirada-compositor
|
|
```
|
|
|
|
- **Enlazado** — el Cuerpo escucha en un socket y la app `mirada` (el
|
|
Cerebro GPUI) se conecta y decide la geometría.
|
|
|
|
```sh
|
|
# terminal 1 — el Cuerpo
|
|
MIRADA_SOCKET=/tmp/mirada.sock cargo run -p mirada-compositor
|
|
# terminal 2 — el Cerebro
|
|
MIRADA_SOCKET=/tmp/mirada.sock cargo run -p mirada
|
|
```
|
|
|
|
## Probarlo
|
|
|
|
Al arrancar imprime el `WAYLAND_DISPLAY` que abrió. Lanza cualquier
|
|
cliente Wayland contra él:
|
|
|
|
```sh
|
|
WAYLAND_DISPLAY=wayland-1 foot # o weston-terminal, alacritty, …
|
|
```
|
|
|
|
Las ventanas se teselan solas. El teclado, con la ventana del compositor
|
|
enfocada, maneja el escritorio con atajos `Super+…`: foco `Super+j/k`,
|
|
ciclar layout `Super+space`, escritorios `Super+1..9`, cerrar `Super+q`.
|
|
Cierra la ventana del compositor para salir.
|
|
|
|
## Atajos de teclado
|
|
|
|
Los atajos son configurables en RON: `~/.config/mirada/keymap.ron`. En
|
|
modo autónomo, el Cuerpo lo carga al arrancar (si no existe, escribe uno
|
|
por defecto documentado) y lo **recarga en caliente** — edita el archivo,
|
|
guarda, y los atajos cambian sin reiniciar. En modo enlazado el keymap es
|
|
asunto del Cerebro (la app `mirada`).
|
|
|
|
```sh
|
|
cargo run -p mirada-brain --example keymap-default # ver el formato
|
|
```
|
|
|
|
El compositor en sí no interpreta atajos: sólo intercepta las
|
|
combinaciones que el Cerebro le pide (`GrabKeys`) y le devuelve la
|
|
pulsada. *Qué significa* cada una lo decide `mirada-brain`. Ver el SDD.
|
|
|
|
## Control externo
|
|
|
|
En modo autónomo, el compositor abre un socket de control y `mirada-ctl`
|
|
lo maneja desde la terminal — al estilo de `swaymsg`/`hyprctl`:
|
|
|
|
```sh
|
|
mirada-ctl focus-next # cambia el foco
|
|
mirada-ctl focus-window 5 # enfoca una ventana concreta
|
|
mirada-ctl workspace 3 # va al escritorio 3
|
|
mirada-ctl windows # lista las ventanas
|
|
```
|
|
|
|
En modo enlazado el socket de control lo abre el Cerebro (la app
|
|
`mirada`), no el compositor.
|
|
|
|
## Qué implementa
|
|
|
|
`wl_compositor`, `xdg_shell` (toplevels y popups), `wl_shm`, `wl_seat`
|
|
(teclado) y `wl_data_device` (selección). Composición con `GlesRenderer`.
|
|
|
|
Reusa `mirada-body` para la contabilidad de salidas y superficies, y
|
|
`mirada-link` para el cable hacia un Cerebro externo. Toda la lógica
|
|
espacial es agnóstica de Wayland y vive en los crates de
|
|
`crates/modules/mirada/`.
|
|
|
|
## Pendiente
|
|
|
|
Backend nativo DRM/libinput (de ventana anidada a sesión real),
|
|
puntero/ratón completo y aislamiento de clientes. Ver el SDD.
|
|
|
|
[`smithay`]: https://github.com/Smithay/smithay
|