ov-selkies/skills/mutter/SKILL.md
GNOME Mutter Wayland compositor running headless inside containers with virtual monitor. Use when working with Mutter, GNOME desktop, or headless compositor setup.
npx skillsauth add overthinkos/overthink-plugins mutterInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
| Property | Value |
|----------|-------|
| Dependencies | dbus |
| Service | mutter (supervisord, priority 10) |
| Install files | layer.yml, tasks:, mutter-wrapper |
| Variable | Value |
|----------|-------|
| XDG_RUNTIME_DIR | /tmp |
| WAYLAND_DISPLAY | wayland-0 |
| XDG_CURRENT_DESKTOP | GNOME |
| XDG_SESSION_TYPE | wayland |
| EGL_LOG_LEVEL | fatal |
mutter (RPM) -- GNOME Wayland compositor (has hard deps on libeis and pipewire)xorg-x11-server-Xwayland (RPM) -- XWayland supportmesa-dri-drivers, mesa-vulkan-drivers, libglvnd-egl, libglvnd-gles, egl-wayland (RPM) -- GPU drivers/tmp/pipewire-0) and D-Bus session socketmutter --headless --virtual-monitor 1920x1080wayland-0 if neededWAYLAND_DISPLAY and XDG_SESSION_TYPE to D-Bus activation environmentMutter registers native D-Bus interfaces (not Wayland protocols):
org.gnome.Mutter.ScreenCast -- PipeWire-based screen captureorg.gnome.Mutter.RemoteDesktop -- EIS/libei input injectionorg.gnome.Mutter.DisplayConfig -- Display/monitor managementThis is architecturally different from KWin (Wayland protocol) and Sway (wlr-screencopy). The D-Bus interfaces work in headless mode.
xdg-desktop-portal-gnome requires XDG_SESSION_TYPE=wayland to initialize its display server connection. Without it, ScreenCast/RemoteDesktop interfaces are not registered. This env var is normally set by gdm/gnome-session but must be set explicitly in headless containers.
/ov-foundation:dbus -- D-Bus session bus (dependency)/ov-selkies:kwin -- KDE compositor (alternative, disabled due to screencast limitation)/ov-selkies:sway -- wlroots compositor (alternative)/ov-selkies:niri -- Smithay compositor (alternative)/ov-selkies:mutter-apps -- GNOME desktop applications/ov-selkies:mutter-desktop -- full Mutter desktop compositionNot used in any current image definition. Part of the mutter-desktop metalayer composition.
Use when working with:
/ov-build:layer — layer authoring reference (layer.yml schema, task verbs, service declarations)/ov-build:eval — declarative testing (tests: block, ov eval image, ov test)development
Claude Code multi-agent support in Overthink — sub-agents, dynamic workflows, and agent teams, and how each drives the existing `ov eval` disposable beds to test and verify. MUST be invoked before authoring or invoking an ov sub-agent / dynamic workflow / agent team, wiring agent-lifecycle hooks, or asking "which primitive should drive the R10 beds?".
tools
Mounts a virtiofs share tagged `workspace` at /workspace inside a VM guest via a systemd .mount unit. Use when a kind:vm entity shares a host directory into the guest and you need it auto-mounted (and re-mounted at every boot).
development
MUST be invoked before any work involving: the `kind: android` schema kind, a `target: android` deploy, the `apk:` layer package format (installing Android apps declaratively), AndroidDeployTarget, an in-pod emulator OR a remote/physical adb-endpoint device, or nested `pod → android` deployment. The first-class Android device + app surface that sits above `ov eval adb`/`appium`.
tools
Use when committing, branching, pushing, merging, tagging, creating PRs, or approving/merging PRs with gh — the feat/-branch, R10-gated, never-force-push landing workflow across the main repo + the plugins submodule + image/<distro> submodules. Covers sync-to-upstream, branch/worktree pruning, the fork+PR path for contributors without write access, and cross-repo @github landing order.