selkies/skills/wl-tools/SKILL.md
# wl-tools - Compositor-Agnostic Desktop Automation Tools ## Overview Provides CLI tools for desktop automation — Wayland-native, X11, and clipboard. Used by the `ov eval wl` command. Works on all wlroots compositors (sway, labwc). No daemon or special device access needed. **Note:** Screenshots are NOT included in this layer. Use `wl-screenshot-grim` (sway) or `wl-screenshot-pixelflux` (selkies) depending on your compositor. ## Layer Definition ```yaml rpm: packages: - wtype - wl
npx skillsauth add overthinkos/overthink-plugins selkies/skills/wl-toolsInstall 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.
Provides CLI tools for desktop automation — Wayland-native, X11, and clipboard. Used by the ov eval wl command. Works on all wlroots compositors (sway, labwc). No daemon or special device access needed.
Note: Screenshots are NOT included in this layer. Use wl-screenshot-grim (sway) or wl-screenshot-pixelflux (selkies) depending on your compositor.
rpm:
packages:
- wtype
- wlrctl
- xdotool
- xprop
- xwininfo
- wl-clipboard
- wlr-randr
- ydotool
No dependencies — compositor-agnostic. Works with sway, labwc, or any wlroots compositor.
| Property | Value |
|----------|-------|
| Depends | None (compositor-agnostic) |
| Packages | wtype, wlrctl, xdotool, xprop, xwininfo, wl-clipboard, wlr-randr, ydotool |
| Service | None (all tools are one-shot CLI commands) |
| Ports | None |
| Tool | Protocol | Purpose |
|------|----------|---------|
| wtype | zwp_virtual_keyboard_v1 | Keyboard input (type text, send keys, key combos with -M) |
| wlrctl | wlr-virtual-pointer, wlr-foreign-toplevel-management | Pointer control (move, click) + window management (list, focus, close, fullscreen, minimize) |
| wl-copy / wl-paste | wlr-data-control | Clipboard read/write |
| wlr-randr | wlr-output-management | Output resolution query and set |
| ydotool | /dev/uinput | Wayland-native mouse drag, scroll (press/release separation) |
| Tool | Purpose |
|------|---------|
| xdotool | X11 window interaction (click, type, key, move, search, activate, scroll) |
| xprop | X11 window property inspection (WM_CLASS, _NET_WM_NAME, _NET_WM_PID) |
| xwininfo | X11 window geometry information |
All packages are in Fedora official repos.
sway-desktop metalayer (+ wl-screenshot-grim for screenshots)selkies-desktop metalayer (+ wl-screenshot-pixelflux for screenshots)| Tool | sway | labwc (selkies) | |------|------|-----------------| | wtype | YES | YES | | wlrctl pointer | YES | YES | | wlrctl toplevel | YES | YES | | wlr-randr | YES | YES | | wl-clipboard | YES | YES | | xdotool | YES (XWayland) | YES (XWayland on-demand) | | ydotool | YES | YES (needs /dev/uinput) |
/ov-selkies:sway-browser-vnc (via sway-desktop metalayer)/ov-selkies:selkies-desktop (via selkies-desktop metalayer)/ov-selkies:selkies-desktop-nvidia (via selkies-desktop metalayer)/ov-eval:wl — CLI command that uses these tools (22 subcommands)/ov-selkies:wl-screenshot-grim — Screenshot layer for sway (grim)/ov-selkies:wl-screenshot-pixelflux — Screenshot layer for selkies (pixelflux pipeline)/ov-selkies:sway-desktop — Desktop metalayer that includes this layer/ov-selkies:selkies-desktop — Desktop metalayer that includes this layer/ov-image:layer — layer authoring reference (layer.yml schema, task verbs, service declarations)/ov-eval:eval — declarative testing (eval: block, ov eval image, ov eval live)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.