Getting started with Battlesnake and Rust
This is a basic implementation of the Battlesnake API in Rust. It's a great starting point for anyone wanting to program their first Battlesnake using Rust, and comes ready to deploy with Replit and Heroku, or you can use any other cloud provider you'd like.
The Quick Start Coding Guide provides the full set of instructions to customize, register, and create your first games with your Battlesnake! While the guide optimizes around local development for quick iteratation, you may choose to host it with Repl.it or a provider of your choice. You can find advice on other hosting providers within our Hosting Suggestions page.
- A free Battlesnake Account
Locate the get_info
function inside logic.rs. Inside that function you should see a line that looks like this:
return json!({
"apiversion": "1",
"author": "",
"color": "#888888",
"head": "default",
"tail": "default",
});
This function is called by the game engine periodically to make sure your Battlesnake is healthy, responding correctly, and to determine how your Battlesnake will appear on the game board. See Battlesnake Personalization for how to customize your Battlesnake's appearance using these values.
Whenever you update these values, go to the page for your Battlesnake and select 'Refresh Metadata' from the option menu. This will update your Battlesnake to use your latest configuration and those changes should be reflected in the UI as well as any new games created.
On every turn of each game your Battlesnake receives information about the game board and must decide its next move.
Locate the get_move
function inside logic.rs. Possible moves are "up", "down", "left", or "right". To start your Battlesnake will choose a move randomly. Your goal as a developer is to read information sent to you about the board and decide where your Battlesnake should move next. This is the code you will want to edit.
See the Battlesnake Game Rules for more information on playing the game, moving around the board, and improving your algorithm.
Because rocket requires an up to date build of rust we recommend you use rustup to get started then set the project to use the latest stable builds
Note: You cannot create games on play.battlesnake.com using a locally running Battlesnake unless you install and use a port forwarding tool like ngrok.
We're look for a community member to produce a very simple test suite for developers to expand! If this is something you are able to do, please feel free to make a Pull Request.
If you are interested in using Heroku to deploy your Battlesnake, you will need to specify a buildpack as Heroku does not directly supply one for Rust. You can use the Heroku Buildpack for Rust and substitue the following Heroku commands for step 2 of the Battlesnake Heroku guide. :
heroku create [YOUR-APP-NAME]
heroku buildpacks:set emk/rust
git push heroku main
heroku open
If you're looking for the Single Player Mode of Battlesnake, or something to practice with between events, check out Challenges.
Once you've made your Battlesnake behave and survive on its own, you can enter it into the Global Battlesnake Arena to see how it performs against other Battlesnakes worldwide.
Arenas will regularly create new games and rank Battlesnakes based on their results. They're a good way to get regular feedback on how well your Battlesnake is performing, and a fun way to track your progress as you develop your algorithm.
Want to get out there to compete and win prizes? Check out the Quick Start League Guide for information on the how and when of our competitive seasons.
All documentation is available at docs.battlesnake.com, including detailed Guides, API References, and Tips.
You can also join the Battlesnake Developer Community on Discord. We have a growing community of Battlesnake developers of all skill levels wanting to help everyone succeed and have fun with Battlesnake :)
Check out live Battlesnake events on Twitch and see what is happening when on the Calendar.
Want to contribute to Battlesnake? We have a number of open-source codebases and would love for you to get involved! Check out our page on Contributing.
Do you have an issue or suggestions for this repository? Head over to our Feedback Repository today and let us know!