# Eclipse uProtocol Rust library This is the [uProtocol v1.6.0-alpha.4 Language Library](https://github.com/eclipse-uprotocol/uprotocol-spec/blob/v1.6.0-alpha.4/languages.adoc) for the Rust programming language. The crate can be used to * implement uEntities that communicate with each other using the uProtocol [Communication Layer API](https://github.com/eclipse-uprotocol/up-spec/blob/v1.6.0-alpha.4/up-l2/api.adoc) over one of the supported transport protocols. * implement support for an additional transport protocol by means of implementing the [Transport Layer API](https://github.com/eclipse-uprotocol/up-spec/blob/v1.6.0-alpha.4/up-l1/README.adoc). ## Using the Crate The crate needs to be added to the `[dependencies]` section of the `Cargo.toml` file: ```toml [dependencies] up-rust = { version = "0.1" } ``` Most developers will want to use the Communication Level API and its default implementation which are provided by the `communication` module. ## Building from Source First, the repository needs to be cloned using: ```sh git clone --recurse-submodules git@github.com:eclipse-uprotocol/up-rust ``` The `--recurse-submodules` parameter is important to make sure that the git submodule referring to the uProtocol type definitions is being initialized in the workspace. The proto3 files contained in that submodule define uProtocol's basic types and are being compiled into Rust code as part of the build process. If the repository has already been cloned without the parameter, the submodule can be initialized manually using `git submodule update --init --recursive`. The crate can then be built using the [Cargo package manager](https://doc.rust-lang.org/cargo/) from the root folder: ```sh cargo build ``` The crate has some (optional) _features_ as documented in [lib.rs](src/lib.rs). VSCode can be instructed to build all features automatically by means of putting the following into `./vscode/settings.json`: ```json { "rust-analyzer.cargo.features": "all" } ``` ### Generating API Documentation The API documentation can be generated using ```sh cargo doc --no-deps --all-features --open ``` ## License The crate is published under the terms of the [Apache License 2.0](LICENSE). ## Contributing Contributions are more than welcome. Please refer to the [Contribution Guide](CONTRIBUTING.md).