๐Ÿ“ฆ woodruffw / x_do.cr

Crystal bindings for libxdo (xdotool)

โ˜… 16 stars โ‘‚ 1 forks ๐Ÿ‘ 16 watching โš–๏ธ MIT License
crystallibxdox11
๐Ÿ“ฅ Clone https://github.com/woodruffw/x_do.cr.git
HTTPS git clone https://github.com/woodruffw/x_do.cr.git
SSH git clone git@github.com:woodruffw/x_do.cr.git
CLI gh repo clone woodruffw/x_do.cr
William Woodruff William Woodruff README: update license badge a8eea4c 2 years ago ๐Ÿ“ History
๐Ÿ“‚ master View all commits โ†’
๐Ÿ“ .github
๐Ÿ“ examples
๐Ÿ“ spec
๐Ÿ“ src
๐Ÿ“ util
๐Ÿ“„ .editorconfig
๐Ÿ“„ .gitignore
๐Ÿ“„ LICENSE
๐Ÿ“„ README.md
๐Ÿ“„ shard.yml
๐Ÿ“„ README.md

x_do ====

License: MIT CI

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.

Installation

Add this to your application's shard.yml:

dependencies:
  x_do:
    github: woodruffw/x_do.cr

libxdo is required. On Debian-based systems, it can be installed via:

$ sudo apt install libxdo-dev

Usage

require "x_do"

XDo.act do
  active_window do |win|
    win.type "hello from Crystal!"
  end
end

Check out the examples folder for some practical examples.

Testing

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 xlogo installed
To run the unit tests on the default X11 display (DISPLAY, falling back on :0):

$ crystal spec

Alternatively, the tests can be run on another X11 display, like a Xephyr or Xvfb instance:

# replace "99" with your display number
$ DISPLAY=:99 crystal spec

The util/xvfb-spec script can be used to run the tests inside a temporary Xvfb instance running Openbox:

$ ./util/xvfb-spec

TODO

  • Complete bindings (grep "implement me!")
  • Add error conditions (check return value of libxdo calls)

Contributing

  • 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

Contributors

  • woodruffw William Woodruff - creator, maintainer