Rust language bindings for ev3dev

Build Latest version

Notice

To use this project with the BrickPi platform the corresponding feature has to be enabled. The features ev3, brickpi and brickpi3 are mutual exclusive. toml [dependencies] ev3dev_lang_rust = { version="0.13.0" default-features=false, features=["brickpi"] }

Usage

```rust extern crate ev3devlangrust;

use ev3devlangrust::Ev3Result; use ev3devlangrust::motors::{LargeMotor, MotorPort}; use ev3devlangrust::sensors::ColorSensor;

fn main() -> Ev3Result<()> {

// Get large motor on port outA.
let large_motor = LargeMotor::get(MotorPort::OutA)?;

// Set command "run-direct".
large_motor.run_direct()?;

// Run motor.
large_motor.set_duty_cycle_sp(50)?;

// Find color sensor. Always returns the first recognized one.
let color_sensor = ColorSensor::find()?;

// Switch to rgb mode.
color_sensor.set_mode_rgb_raw()?;

// Get current rgb color tuple.
println!("Current rgb color: {:?}", color_sensor.get_rgb()?);

Ok(())

} ```

There is a template repository that contains all the required configurations for cross-compilation and performance/binary-size optimizations for this "Hello World" example.

Supported features

Cross compilation for the ev3 robot - using musl toolchain

  1. Install the armv5te-musl toolchain

    bash rustup target add armv5te-unknown-linux-musleabi

  2. Create .cargo/config.toml with the following content

    ```toml [build] target = "armv5te-unknown-linux-musleabi"

    [target.armv5te-unknown-linux-musleabi] linker = "rust-lld" ```

  3. Build binary

    bash cargo build --release

    The --release flag is optional. However, it can speed up the execution time by a factor of 30. The target binary is now in target/armv5te-unknown-linux-musleabi/release/{application_name}.

Cross compilation for the ev3 robot - using docker

If you need to cross compile other dependencies (eg. openssl or paho-mqtt) it is much easier to use a complete cross compile toolchain. For this you can use the provided docker image pixix4/ev3dev-rust:latest.

  1. Setup a docker environment

  2. Create .cargo/config.toml with the following content

    ```toml [build] target = "armv5te-unknown-linux-gnueabi"

    [target.armv5te-unknown-linux-gnueabi] linker = "/usr/bin/arm-linux-gnueabi-gcc" ```

  3. Build binary

    bash docker run --rm -it -v $(pwd):/build -w /build pixix4/ev3dev-rust:latest \ cargo build --release

    The --release flag is optional. However, it can speed up the execution time by a factor of 30. The target binary is now in target/armv5te-unknown-linux-gnueabi/release/{application_name}.

    If you do this you will notice that each build gets stuck at Updating crates.io index for a long time. To speed up this step you can use the vendoring mechanic of cargo.

    bash cargo vendor

    Execute the above command and add this additional config to .cargo/config.

    ```toml [source.crates-io] replace-with = "vendored-sources"

    [source.vendored-sources] directory = "vendor" ```

Optimize binary size

Editor support

If you have problems with code completion or inline documentation with rust analyzer it may help to enable to following settings:

json { "rust-analyzer.cargo.loadOutDirsFromCheck": true, "rust-analyzer.procMacro.enable": true }

(Example from VSCode settings.json)

Docs.rs documentation

To build the complete documentation (including the screen feature) use:

bash RUSTDOCFLAGS="--cfg docsrs" cargo +nightly doc --features ev3,screen