2018-11-14 06:47:52 +11:00
[![License:Apache2 ](https://img.shields.io/badge/License-Apache2-green.svg )](https://www.apache.org/licenses/LICENSE-2.0)
2021-02-21 05:49:40 +11:00
[![ci ](https://github.com/rust-console/gba/workflows/ci/badge.svg?branch=master )](https://github.com/rust-console/gba/actions?query=workflow%3Aci)
2018-11-15 13:48:45 +11:00
[![crates.io ](https://img.shields.io/crates/v/gba.svg )](https://crates.io/crates/gba)
[![docs.rs ](https://docs.rs/gba/badge.svg )](https://docs.rs/gba/latest/gba/)
2018-11-14 06:47:52 +11:00
2018-11-19 07:09:23 +11:00
* [![Built with cargo-make ](https://sagiegurari.github.io/cargo-make/assets/badges/cargo-make.svg )](https://sagiegurari.github.io/cargo-make)
2018-11-21 17:44:58 +11:00
* ![Stability:None ](https://img.shields.io/badge/Stability-None-red.svg )
2018-11-19 07:09:23 +11:00
2018-11-14 06:47:52 +11:00
# gba
2018-12-30 14:18:09 +11:00
_Eventually_ there will be a full [Tutorial
Book](https://rust-console.github.io/gba/) that goes along with this crate.
However, currently the development focus is leaning towards having minimal
coverage of all the parts of the GBA. Until that's done, unfortunately the book
will be in a rather messy state.
2018-11-14 06:47:52 +11:00
2019-01-03 14:50:05 +11:00
## What's Missing
The following major GBA features are still missing from the crate:
* Affine Graphics
* Interrupt Handling
* Serial Communication
2021-02-21 05:49:40 +11:00
## Build Dependencies
Install required cargo packages
```sh
rustup install nightly
rustup +nightly component add rust-src
cargo install cargo-make
cargo install gbafix
```
Install arm build tools
* Ubuntu
```shell
sudo apt-get install binutils-arm-none-eabi
```
* OSX
```shell
brew install --cask gcc-arm-embedded
```
* Windows
* Download the [GNU Arm Embedded Toolchain ](https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads )
* Install the toolchain, make sure to select "Add path to environment variable" during install
2018-12-15 16:57:14 +11:00
## First Time Setup
2018-11-14 06:47:52 +11:00
2018-12-15 16:57:14 +11:00
Writing a Rust program for the GBA requires a fair amount of special setup. All
2018-12-30 14:18:09 +11:00
of the steps are detailed for you in the [Development
Setup](https://rust-console.github.io/gba/development-setup.html) part at the
start of the book.
2018-11-14 06:47:52 +11:00
2018-12-15 16:57:14 +11:00
If you've done the described global setup once before and just want to get a new
project started quickly we got you covered:
2018-11-19 02:25:32 +11:00
```sh
2018-11-19 02:41:06 +11:00
curl https://raw.githubusercontent.com/rust-console/gba/master/init.sh -sSf | bash -s APP_NAME
2018-11-19 02:25:32 +11:00
```
2018-11-14 06:47:52 +11:00
# Contribution
This crate is Apache2 licensed and any contributions you submit must also be
Apache2 licensed.