Minecraft game clone written in Rust, using the Bevy game engine.
- Procedurally generated worlds with biomes (Plains, Forest, Mountains, Desert, Ice Plain), trees and flowers.
- Multiplayer functionality.
- Dynamic day/night cycle
- Block breaking and placing mehanics.
- Inventory system with a functional hotbar.
- World saving and loading.
- Customizable keybindings and dynamic render distance adjustment.
You can download the game for Windows and Linux from the Releases page of the GitHub repository.
Once downloaded, extract the archive for your operating system. The executable will be located in the /bin
folder of the extracted directory.
Movement
- Jump: Space
- Strafe Left: A / Arrow Left
- Strafe Right: D / Arrow Right
- Walk Backward: S / Arrow Down
- Walk Forward: W / Arrow Up
- Toggle Fly Mode: F
- Fly Up: Space
- Fly Down: Left Shift
Gameplay
- Destroy Block: Left Mouse Button
- Place Block: Right Mouse Button
Inventory
- Open/Close Inventory: E
- Pick up stack: Left Click
- Pick up half of stack: Right Click (with empty mouse)
- Deposit 1 item: Right Click (over valid stack)
- Deposit MAX items: Left Click (over valid stack)
- Exchange stacks: Left Click (over a different stack or full valid stack)
> A "valid stack" refers to a stack in the inventory that is either empty or contains the same items as the mouse cursor.
Miscellaneous
- Toggle FPS Display: F3
- Toggle Perspective: F5
- Toggle Chunk Debug: F4
- Toggle Block Debug: F6
- Decrease Render Distance: O
- Increase Render Distance: P
- Exit Game: Escape
To build and run this project, you need the following tools and dependencies installed:
- Install Rust using Rustup
- After installation, add the Nightly toolchain with the Cranelift backend:
rustup install nightly rustup default nightly rustup component add rustc-codegen-cranelift-preview --toolchain nightly
- Just is used in this project to manage build. Install it using Cargo:
cargo install just
Note: You can also install Just using your system's package manager.
Install the required dependencies based on your operating system:
sudo pacman -S base-devel mold clang vulkan-radeon vulkan-tools
- Replace
vulkan-radeon
with:
-vulkan-intel
for Intel GPUs.
-nvidia-utils
for NVIDIA GPUs.
sudo apt update && sudo apt install -y \
build-essential mold clang mesa-vulkan-drivers vulkan-tools
- For NVIDIA GPUs, also install:
sudo apt install -y nvidia-driver nvidia-vulkan-icd
- Git Bash is required to ensure the commands in the
Justfile
and scripts run correctly. Download and install Git Bash. - After installation, make sure Git Bash is added to your system's
PATH
. You can verify it by running:bash --version
To compile and run the game locally, use the following commands:
Note: the first compilation will be slow depending on your hardware, next compilations will be incremental and thus faster.
# Clone the repository
git clone https://github.com/c2i-junia/rustcraft
# Navigate to the project directory
cd rustcraft
Debug mode:
./run-server.sh # this will compile the project and run the server
./run1.sh # this will compile the project and run the client
Release mode:
# Build the project in debug or release mode
just generate-release-folder
# Run the executable
./release/bin/rustcraft # run the client
./release/bin/rustcraft-server # run the server
Feel free to submit issues or open pull requests. If you want to know where to help, refer to the existing issues.
Run cargo fmt
before committing.
We follow the Conventional Commit specification.
<type>[optional scope]: <description>
[optional body]
[optional footer(s)]
Our commit types are inspired by the Karma specification
Allowed values:
- feat for a new feature for the user, not a new feature for build script. Such commit will trigger a release bumping a MINOR version.
- fix for a bug fix for the user, not a fix to a build script. Such commit will trigger a release bumping a PATCH version.
- perf for performance improvements. Such commit will trigger a release bumping a PATCH version.
- docs for changes to the documentation.
- style for formatting changes, missing semicolons, etc.
- refactor for refactoring production code, e.g. renaming a variable.
- test for adding missing tests, refactoring tests; no production code change.
- build for updating build configuration, development tools or other changes irrelevant to the user.
Write commit messages in the present tense (e.g., "Add feature X" instead of "Added feature X").
If a commit is co-authored by multiple people, do not hesitate to add a Co-authored-by
field. See GitHub documentation. For example:
$ git commit -m "Refactor usability tests.
>
>
Co-authored-by: NAME <[email protected]>
Co-authored-by: ANOTHER-NAME <[email protected]>"
- Use the naming convention
<type>/<name>
for branches introducing new features. Only use lowercase letters, numbers, and dashes. - The
main
branch should always compile successfully and be free of warnings. Usecargo check
. - Experimental branches are allowed to include code that does not build successfully.
- Prefer rebasing over merging.