pros 0.9.1

Rust bindings for PROS
Documentation
# Pros-rs

Opinionated Rust bindings for the [PROS](https://github.com/purduesigbots/pros) library and kernel.

![Maintained: no](https://img.shields.io/maintenance/no/2024)

> [!important]
> pros-rs is deprecated and unmaintained; new projects should instead use
> [`vexide`]https://crates.io/crates/vexide, a similar library with features like differential
> uploading and `std` support.

## Usage

## Compiling

The only dependency of pros-rs outside of Rust is The Arm Gnu Toolchain (arm-none-eabi-gcc).

Read the installation guide for your OS to see how to get things set up.

### Windows
Steps:
1. Run The Arm Gnu Toolchain [here]https://developer.arm.com/downloads/-/arm-gnu-toolchain-downloads
2. Install the pros cli, instructions are [here]https://pros.cs.purdue.edu/v5/getting-started/windows.html
3. Install cargo pros with ``cargo install cargo-pros``

To compile the project just run ``cargo pros build``.

### Linux

The steps for getting pros-rs compiling are slightly different based on if you use Nix or not.

#### With Nix

The Nix flake contains the Arm GNU Toolchain, cargo pros, and pros-cli.

There is a ``.envrc`` file included for Nix + Direnv users.

#### Without Nix

Install arm-none-eabi-gcc and pros-cli from your package manager of choice.
Cargo pros can be installed with ``cargo install cargo-pros``.

### MacOS

This project depends on the Xcode Command Line Tools.
Chances are that if you develop on MacOS you have them already, but if not you can install them with `xcode-select --install`.

Most of the other dependencies can easily be installed with Homebrew.

Install the Arm GNU Toolchain with
`brew install osx-cross/arm/arm-gcc-bin`.

Install pros-cli with
`brew install purduesigbots/pros/pros-cli`.

And you are done! Compile the project with `cargo build`.

## Compiling for WASM

To build projects in this repository for WebAssembly, run ``cargo pros build -s``
This will automatically pass all of the correct arguments to cargo.

If for some reason you want to do it manually, this is the command:
`cargo build --target wasm32-unknown-unknown -Zbuild-std=std,panic_abort`.

The extra build-std argument is neccesary because this repository's `.cargo/config.toml` enables build-std but only for core, alloc, and compiler_builtins. WebAssembly does come with `std` but there is [currently](https://github.com/rust-lang/cargo/issues/8733) no way to conditionally enable build-std.