Skip to content

Latest commit

 

History

History
91 lines (67 loc) · 3.5 KB

getting-started.md

File metadata and controls

91 lines (67 loc) · 3.5 KB

Getting Started

This guide will show how to setup a local development environment to build, test, and contribute to our modules.

Table of contents

Installation

To contribute to our project you need to install Git and a text editor. We recommend VSCode.

Our modules are built using beet, which is a Python framework that allows us to automatically validate and generate part of our data packs and resource packs.

You will need to install uv as project manager. If you don't already have Python installed, uv will do that automatically.

# MacOS, Linux, or Git Bash (recommended)
curl -LsSf https://astral.sh/uv/install.sh | sh

# Powershell on Windows
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"

Create your own fork of this repository. Forking the repository on GitHub

Clone your fork locally:

git clone https://github.com/<username>/GM4_Datapacks.git

Open the GM4_Datapacks folder in VScode. Then run uv sync. This will install beet and all our other dependencies.

You are now ready to build our modules and make changes!

Building modules

The source of each module is stored in each gm4_* folder. To convert them to a valid data pack, you need to use Beet:

uv run beet dev --link <world_name> --watch metallurgy *_shamir
  • uv run makes sure that the command uses the correct Python dependencies
  • beet dev builds the data packs to the out folder
  • --link <world_name> copies the packs to a local world
  • --watch watches for file changes and then rebuilds
  • metallurgy *_shamir specifies the list of module IDs to build

Building the release version of all modules is also possible. It will output the zipped data packs in the release/<version> folder. Running this could take a few minutes!

uv run beet -p beet-release.yaml build

Submitting changes

To submit changes to our modules, start by creating a branch. This allows us to review every change separately and allows you to make other changes in the future. Make sure you are on the master branch when you do this.

Creating a new branch in VSCode

Alternatively, to create a branch, you can run:

git checkout -b <branch_name>

While making changes, test the data packs in a local world:

uv run beet dev --link <world_name> --watch <module_id>

When you are happy with the changes, create a commit on the branch. Creating a commit in VSCode

Alternatively, to create a commit, you can run:

git add .
git commit -m "<commit_message>"

After committing the changes locally, push them to your fork. Click on "Publish Branch". Pushing a commit in VSCode

Alternatively, to push to the fork, you can run:

git push -u origin <branch_name>

On GitHub, create a pull request for this new branch. Click on "Compare & pull request". Compare & pull request on GitHub

Then, write a short description of the changes you made, whether it fixes a bug or changes behavior of a module. Click on "Create pull request" when you're done. Writing the description of the pull request on GitHub

Your changes are now ready to be reviewed by our contributors. Thank you!