5.5 KiB
Contributing to CC: Tweaked
As with many open source projects, CC: Tweaked thrives on contributions from other people! This document (hopefully) provides an introduction as to how to get started with helping out.
If you've any other questions, just ask the community or open an issue.
Table of Contents
Reporting issues
If you have a bug, suggestion, or other feedback, the best thing to do is file an issue. When doing so, do use the issue templates - they provide a useful hint on what information to provide.
Setting up a development environment
In order to develop CC: Tweaked, you'll need to download the source code and then run it.
-
Make sure you've got the following software installed:
- Java Development Kit 21 (JDK). This can be downloaded from Adoptium.
- Git.
- NodeJS 20 or later.
-
Download CC: Tweaked's source code:
git clone https://github.com/cc-tweaked/CC-Tweaked.git cd CC-Tweaked
-
Build CC: Tweaked with
./gradlew build
. This will be very slow the first time it runs, as it needs to download a lot of dependencies (and decompile Minecraft several times). Subsequent runs should be much faster! -
You're now ready to start developing CC: Tweaked. Running
./gradlew :forge:runClient
or./gradle :fabric:runClient
will start Minecraft under Forge and Fabric respectively.
If you want to run CC:T in a normal Minecraft instance, run ./gradlew assemble
and copy the .jar
from
projects/forge/build/libs
(for Forge) or projects/fabric/build/libs
(for Fabric).
Developing CC: Tweaked
Before making any major changes to CC: Tweaked, I'd recommend you have a read of the the architecture document first. While it's not a comprehensive document, it gives a good hint of where you should start looking to make your changes. As always, if you're not sure, do ask the community!
Testing
When making larger changes, it may be useful to write a test to make sure your code works as expected.
CC: Tweaked has several test suites, each designed to test something different:
-
In order to test CraftOS and its builtin APIs, we have a test suite written in Lua located at
projects/core/src/test/resources/test-rom/
. These don't rely on any Minecraft code, which means they can run on emulators, acting as a sort of compliance test.These tests are written using a test system called "mcfly", heavily inspired by busted. Groups of tests go inside
describe
blocks, and a single test goes insideit
. Assertions are generally written usingexpect
(inspired by Hamcrest and the like). For instance,expect(foo):eq("bar")
asserts that your variablefoo
is equal to the expected value"bar"
.These tests can be run with
./gradlew :core:test
. -
In-game functionality, such as the behaviour of blocks and items, is tested using Minecraft's gametest system (
projects/common/src/testMod
). These tests spin up a server, spawn a structure for each test, and then run some code on the blocks defined in that structure.These tests can be run with
./gradlew runGametest
(or./gradle :forge:runGametest
/./gradlew :fabric:runGametest
for a single loader).
For more information, see the architecture document.
Writing documentation
When writing documentation for CC: Tweaked's documentation website, it may be useful to build the documentation and preview it yourself before submitting a PR.
You'll first need to set up a development environment as above.
Once this is set up, you can now run ./gradlew docWebsite
. This generates documentation from our Lua and Java code,
writing the resulting HTML into ./projects/web/build/site
, which can then be opened in a browser. When iterating on
documentation, you can instead run ./gradlew docWebsite -t
, which will rebuild documentation every time you change a
file.
Documentation is built using illuaminate which, while not currently documented (somewhat ironic), is largely the same as ldoc. Documentation comments are written in Markdown, though note that we do not support many GitHub-specific markdown features. If you can, do check what the documentation looks like locally!
When writing long-form documentation (such as the guides in doc/guides), I find it useful to tell a narrative. Think of what you want the user to learn or achieve, then start introducing a simple concept, and then talk about how you can build on that until you've covered everything!