Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bryal/se-rs-ial

Cross platform lib for serial communication in Rust
https://github.com/bryal/se-rs-ial

Last synced: 11 days ago
JSON representation

Cross platform lib for serial communication in Rust

Awesome Lists containing this project

README

        

# se-rs-ial

Cross-platform serial communications library in Rust.

# Usage Example

use se_rs_ial::{ Connection, BaudRate };

#[cfg(windows)]
const PORT: &'static str = "COM1";
#[cfg(unix)]
const PORT: &'static str = "/dev/ttyUSB0";

let mut conn = Connection::open(PORT, BaudRate::B9600).unwrap();

conn.write("Hello World!\n".as_bytes()).unwrap();

# Documentation

There are minor variances between the builds for the different platforms.

[Documentation for Windows](https://bryal.github.io/se-rs-ial/windows/se_rs_ial/)

[Documentation for Unix-like](https://bryal.github.io/se-rs-ial/unix/se_rs_ial/)

# Building

se-rs-ial depends on serial-win, which makes use of unstable features. As such, Rust Nightly is needed to build the software.

# Examples

Check out the [examples](https://github.com/bryal/se-rs-ial/tree/master/examples) directory.

Examples can be run with `cargo run --example -- `,
where `port` is the serial port, e.g. `COM3` or `/dev/ttyUSB0`. On some systems, `sudo` be required for sufficient permissions.

E.g. `sudo cargo run --example color_swirl -- /dev/ttyS1`