inputplug /

Filename Size Date modified Message
90 B
516 B
1.0 KB
799 B
3.0 KB
11.1 KB
2.8 KB


inputplug is a very simple daemon monitoring XInput events and running scripts on hierarchy changes (such as device attach, remove, enable or disable).

To build the project, it's best to use mk-configure(7), a build system based on bmake(1). However, GNU Makefile is provided for convenience.


inputplug — XInput event monitor


inputplug [-a address] [-f path] [-v] [-n] [-d] [-0] -c command-prefix


inputplug is a daemon which connects to a running X server and monitors its XInput hierarchy change events. Such events arrive when a device being attached or removed, enabled or disabled etc.

When a hierarchy change happens, inputplug parses the event notification structure, and calls the command specified by command-prefix. The command receives three arguments:

  • command-prefix event-type device-id device-type

Event type may be one of the following:

  • XIMasterAdded
  • XIMasterRemoved
  • XISlaveAdded
  • XISlaveRemoved
  • XISlaveAttached
  • XISlaveDetached
  • XIDeviceEnabled
  • XIDeviceDisabled

Device type may be any of those:

  • XIMasterPointer
  • XIMasterKeyboard
  • XISlavePointer
  • XISlaveKeyboard
  • XIFloatingSlave

Device identifier is an integer.

Also, if compiled with libixp, inputplug can post events to the wmii event file. To enable wmii support, the address of its 9P server needs to be specified.


A summary of options is included below.

  • -v

    Be a bit more verbose.

  • -n

    Start up, monitor events, but don't actually run anything. With verbose more enabled, would print the actual command it'd run. This implies -d.

  • -d

    Don't daemonize. Run in the foreground.

  • -0

    On start, trigger added and enabled events for each plugged devices. A master device will trigger the "added" event while a slave device will trigger both the "added" and the "enabled" device.

  • -c command-prefix

    Command prefix to run. Unfortunately, currently this is passed to execvp(3) directly, so spaces aren't allowed. This is subject to change in future.

  • -a address

    The address at which to connect to wmii. The address takes the form <protocol>!<address>. If an empty string is passed, inputplug tries to find wmii automatically.

  • -f path

    Path to the event file within 9P filesystem served by wmii. The default is /event.



    X11 display to connect to.


    wmii address.


Probably, there are some.




Copyright (C) 2013, Andrew Shadura.

Licensed as MIT/X11.


Andrew Shadura