Getting started

Downloading Butano and building their games and examples is easy and doesn't take too much time, pinky promise.

Supported platforms

Butano is built on top of the devkitARM toolchain, so it supports Windows, macOS and Unix-like platforms.

There's also experimental support for Wonderful Toolchain. If you want to try it, go to Getting started with Wonderful Toolchain.

GBA emulator

Before anything, it is convenient to have a GBA emulator at hand, so you don't have to test in real hardware each change you make in your project.

For developing GBA games, mGBA, NanoBoyAdvance, Mesen and the debug version of No$gba are recommended.

devkitARM

The next step is to download and install devkitARM from devkitPro:

  • Install the GBA Development component.
  • Install all members in the gba-dev group if the installer asks for which members to install.
  • Make sure that with the system console (not with the MSYS2 one) you are able to build and run some of the examples located in /path/to/devkitpro/examples/gba:
    • By default, devkitARM is installed in C:\devkitPro\ on Windows and in /opt/devkitpro/ on Ubuntu.
    • To build a devkitARM example, open the system console, cd to the folder of the example you want to build and type make -j8 if your CPU has 8 cores, make -j16 if it has 16 and so on.
    • In particular, you should build and run the Maxmod example located in /path/to/devkitpro/examples/gba/audio/maxmod before going on. Maybe you're going to need to copy the example folder to another place to avoid having permission issues when building it.
ImageImageImage

Python

To execute some of the tools needed to include image and audio files in your project, you are going to need Python.

If you are going to install Python on Windows, remember to add it to the PATH and to close all system console windows before installing it:

Image

Both Python 2 and Python 3 are supported for now, but Python 2 is not going to be supported for too long. Make sure you can execute Python from the system console:

ImageImage

If you have an Ubuntu/Debian based system with python3 instead of python, you can:

  • Specify python3 as the Python interpreter path in the Makefile of the project you are trying to build.
  • Install python-is-python3: sudo apt-get install python-is-python3.

Butano

Download or clone the latest Butano release from GitHub and put it in a path without spaces or anything weird, please.

Butano examples

Butano contains multiple examples of most aspects of the engine.

Make sure that you are able to build and run some of them:

  • They are located in /path/to/butano/examples/.
  • As with devkitARM examples, to build a Butano example, open the system console (not the MSYS2 one), cd to the folder of the example you want to build and type make -j8 if your CPU has 8 cores, make -j16 if it has 16 and so on.

When trying to build the sprites example, if everything went as expected, a sprites.gba file should have been generated in the sprites folder, and the system console should show something like this:

ImageImage

Make your own GBA game!

If you were able to build and run some examples, congrats! Now you can make your own GBA game with Butano. To do that:

  • Copy the template project located in /path/to/butano/template/ to a path without spaces or weird characters.
  • Change in the Makefile the path in which Butano library folder is located. For example, if Butano is located in /path/to/butano/, LIBBUTANO variable should be set to /path/to/butano/butano.
  • If you want, you can also change ROM title, ROM code and more in the Makefile.
  • cd to the new folder.
  • Type make -j#cpu_cores# again.

If everything went as expected, a *.gba file should have been generated in the project folder!

Now learn how to import your assets in the game and also take a look at the modules page. It's always a good idea to play around with the examples as they cover most of what Butano offers. The frequently asked questions (FAQ) are worth a look too, as they answer most of the initial questions.