XDo is a Crystal interface for libxdo,
the C library that backs xdotool.
It exposes most of the functionality of xdotool, allowing
users to write Crystal programs that manage windows in an X11 instance.
Add this to your application's shard.yml:
dependencies:
x_do:
github: woodruffw/x_do.crlibxdo is required. On Debian-based systems, it can be installed via:
$ sudo apt install libxdo-devrequire "x_do"
XDo.act do
active_window do |win|
win.type "hello from Crystal!"
end
endCheck out the examples folder for some practical examples.
The unit tests make the following assumptions:
- You're running an instance of X11
- You're running a window manager that's (mostly) ICCCM and EWMH compliant
- You have
xlogoinstalled
To run the unit tests on the default X11 display (DISPLAY, falling back on :0):
$ crystal specAlternatively, the tests can be run on another X11 display, like a Xephyr or Xvfb instance:
# replace "99" with your display number
$ DISPLAY=:99 crystal specThe util/xvfb-spec script can be used to run the tests inside a temporary Xvfb instance running
Openbox:
$ ./util/xvfb-spec- Complete bindings (
grep "implement me!") - Add error conditions (check return value of libxdo calls)
- Fork it ( https://github.com/woodruffw/x_do/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
- woodruffw William Woodruff - creator, maintainer