AT-SPI for Rust

crates.io badge docs.rs badge

Higher level, asynchronous pure Rust AT-SPI2 protocol implementation using zbus.

Part of the Odilia screen reader project.

Design

This crate makes use of the zbus crate for dbus communication. We use the asynchronous zbus API, so to use atspi, you will need to run an async executer like tokio or async-std. The async-io and tokio features are exposed and will be passed through to zbus.

Contributing

We love people who add functionality, find bugs, or improve code quality! You can clone the repository and make modifications just by git clone-ing the repository like so:

bash git clone https://github.com/odilia-app/atspi cd atspi cargo build

If you have permissions to publish to crate to crates.io, then please make sure to tag it like so, pushing it to get, and then publishing to crates.io:

bash git tag -a vMAJ.MIN.PATCH -m "New feature in tag" git push origin --tags

Code Generation

Some files are auto-generated, and these will be noted with documentation. If you want to change those files, you will need to make changes in the atspi-codegen binaries, since any changes in the files will be overwritten when the XML is updates and the .rs files are re-generated.

Currently, only one file is 100% auto-generated: identify.rs; and it was generated with the atspi-codegen/target/debug/identify file.

License

The atspi library is licensed as Apache 2.0 or MIT.