This repository has been archived by the owner on Apr 2, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
Contributing
Daomephsta edited this page Sep 2, 2019
·
4 revisions
So, you've found some constants that need unpicking? Here's how to contribute definitions for them to Weft.
- Fork and clone Weft
- Familiarise yourself with V2 of the Unpick format.
- Determine whether the constants exist in one of Minecraft's libraries or not. Look at call hierarchies and take your best guess. If you guess wrong, it can be corrected when other contributors review your PR. If the constants exist in an MC library, proceed to 3i; otherwise proceed to 3ii.
- Look up the maven identifier for the library here. Check if it already has a constantSource tag inside the config tag in warp-config.xml. A constantSource tag looks like
<constantSource mavenStyleId = "somemavenid"/>
. If it doesn't, add one. - Add the constants to the Weft Constant Library. Look in the main sourceset (src/main/java), in the package
io.github.weavemc.weft
. If there's an appropriate class, add the constants to it, otherwise create one and name it according to the naming conventions below.
- Look up the maven identifier for the library here. Check if it already has a constantSource tag inside the config tag in warp-config.xml. A constantSource tag looks like
- If there's an appropriate unpick definition file in the unpick-definitions directory; add the new constants, constant groups, and target method definitions to it; otherwise create one and name it according to the naming conventions below.
- Test your changes.
- Run
./gradlew publishToMavenLocal
from a command prompt in the weft directory. - Create a simple test project with Loom & Warp. Add
mavenLocal
to the repositories block, and change the maven identifier for theunpickDefinitions
configuration toio.github.weavemc:weft:1.14.4+build.unknown
. - Run
./gradlew genSources
from a command prompt in the test project directory. Import it into your IDE and check the added constants and target methods are uninlined correctly.
- Run
- Open a pull request!
Unpick definition files should be named in lower_snake_case, according to the constant groups they contain (e.g gl11.unpick for OpenGL 1.1 constants).
Constant groups should use lower_snake_case.
Follow java naming conventions.
Follow java naming conventions. Classes should use the PascalCase form of the id of the constant group for the constants they define. If you have any questions, you can ask them in this Discord channel.