Skip to content

A match-3 game in VGA graphics on an x86-64 CPU, written in no-std Rust

License

Notifications You must be signed in to change notification settings

nopeless/csci320-match3

 
 

Repository files navigation

Match3!

game_screen

A no-std Rust game for x86-64 CPUs

Match3! is a puzzle game inspired by Bejeweled and written in bare-metal Rust. It is my CSCI 320 midterm project, made in one week (but mostly on Saturday night).

Setup

Although it should theoretically run on any Intel x86-64 computer, I have had little success in doing so; for best results, run in a Qemu x86-64 emulator:

qemu-system-x86_64 -drive format=raw,file=bootimage-csci320-match3.bin

Ensure that Qemu is in your PATH and the command is run in the project's root directory.

Building

Original instructions

# Make sure you have nightly toolchain
rustup toolchain list
rustup toolchain install nightly
# optional
rustup default nightly

# Attempting to build will give "no rust-src" error
rustup component add rust-src --toolchain nightly-<host-triple>

# Build the project
cargo build

# Create a bootable disk image
cargo install bootimage
# Install components
rustup component add llvm-tools-preview

# Build the disk image
cargo bootimage

# Run
qemu-system-x86_64 -drive format=raw,file=target/x86_64-blog_os/debug/bootimage-csci320-match3.bin

How to Play

home_screen

When the game boots up, the home screen will open. From here, enter a text code up to 80 characters long to generate a procedurally random starting position, then press Enter.

During the game, colored gems will fall from the top of the screen to fill any gaps on the board. If, when the gems settle, there are three or more gems of the same color in a row vertically or horizontally (called a "match"), those gems will disappear and score points. The player can swap any gem with an adjacent one if the swap creates a match. Once there are no more possible matches to make, the game ends.

Controls

  • WASD / Arrow Keys - move the cursor
  • Enter / Space - select/deselect a gem; this toggles between cursor mode and swapping mode
  • Escape - return to the menu screen; must be pressed twice if the game is not yet over

About

A match-3 game in VGA graphics on an x86-64 CPU, written in no-std Rust

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%