Skip to content

C++ bindings for Node.js to handle X11 using the full power of libxdo.

Notifications You must be signed in to change notification settings

native-bindings/xdotool

Repository files navigation

xdotool

C++ bindings for Node.js to handle X11 using the full power of libxdo.

Installation

yarn add xdotool

Examples

Key logging

A few lines of code and you're able to spy what key strokes are being pressed on the keyboard:

const bindings = new XdoToolBindings();
const kbd = new KeyboardAsync(bindings);
while(true) { // Keeps printing until you kill the process
    const buffer = Buffer.from(await kbd.queryKeymap(), 0, 32);
    for(let j = 0; j < 32; j++) {
        for(let h = 0; h < 8; h++) {
            if(buffer[j] & (1 << h)) {
                const keycode = j * 8 + h;
                const keysym = kbd.keycodeToKeysym(keycode);
                console.log(kbd.keysymToString(keysym));
            }
        }
    }
}

Activate window

In the example below we look for windows with the name of Visual Studio Code. If any valid match is found, we focus it.

import { XdoToolAsync, XdoToolBindings } from 'xdotool';

// Activate Visual Studio Code window
function activateVisualStudioCodeWindow() {
    const xdo = new XdoToolAsync(new XdoToolBindings());
    const windows = await xdo.searchWindows({
        winclassname: 'Visual Studio Code'
    });
    for(const w of windows) {
        if(!(await xdo.windowHasProperty(w, '_NET_WM_DESKTOP'))) {
            continue;
        }
        await xdo.activateWindow(w);
        break;
    }
}

Screenshot

Our X11-based screenshooter is only capable of returning raw 8-bit RGB image format data at the moment but it is very fast and memory efficient. Getting a screenshot is super simple:

import { ScreenshooterAsync, XdoToolBindings } from 'xdotool';
import { promises as fs } from 'fs';

async function screenshot() {
    const xdo = new XdoToolBindings();
    const screenshooter = new ScreenshooterAsync(xdo);
    const arrayBuffer = await screenshooter.getImage();
    fs.writeFile(`${__dirname}/screenshot_${new Date()}.rgb`, Buffer.from(arrayBuffer));
}

For obvious reasons, the ArrayBuffer returned by screenshooter.getImage is reused on every call. So, unless you create a new instance of screenshooter, if you try to keep the reference, it'll be changed if you're calling this method elsewhere at the same time.

Requirements

  • Boost
  • CMake
  • libx11
  • xdotool

About

C++ bindings for Node.js to handle X11 using the full power of libxdo.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published