Rust language bindings for ev3dev

Build Latest version

Notice

Currently this project is not compatible with the BrickPi platform.

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)