To get updated version of carpet for 1.14 and above, check ▶️  https://github.com/gnembon/fabric-carpet project, that uses fabric framework.
The most comprehensive and convoluted mod for carpets evar. Built based on jarmod-buildsystem-2 by Earthcomputer using Forge Gradle system by Minecraft Forge team. See Earthcomputer's repo for details on the build system.
- Then go get the install package (zip folder) for your system from https://github.com/gnembon/carpetmod/releases , and follow the README that is inside of the zip package. Each installer contains patches for both server and singleplayer versions, and (the best case scenario) should require you to just doubleclick (running) on one patching script.
- Run /carpet listto see all the togglable options with description
- Click on a feature in the list in chat, or type /carpet <featureName>to get detailed help about each feature.
- Have Java SDK and git installed (prefferably, or download zipped repo to a folder)
- open command prompt
- type:
- 
- git clone https://github.com/gnembon/carpetmod.git
 
- 
- cd carpetmod
 
- 
- gradlew setup
 
- 
- gradlew genPatches
 
- 
- gradlew createRelease
 
- patches for client and server are in /build/distributions
- optionally (to patch the server automatically)
- 
- have commandline 7za installed
 
- 
- patch_server.cmd
 
- 
- your server should be running in your saves folder already. Connect to localhost
 
- your server should be running in your saves folder already. Connect to 
- optionally: create installers (depending on the host OS and target OS)
- 
- cd installer
 
- 
- create_installer_<win|mac|ux>.<cmd|sh>
 
- You need to have at least JDK8 update 92 for recompilation to work, due to a bug in earlier versions of javac. You also cannot use JDK9 or JDK10 yet.
- You need to have gitinstalled.
- Eclipse Oxygen.3 or later, due to this Eclipse bug.
- Or Intellij
OR
- Download the patches from the releases section and apply them directly to game's or server's jars.
- Copy all the files in this repository into your new project folder.
- Run gradlew setupto decompile, deobfuscate the code and apply carpet patches.
- Run gradlew eclipseto setup the appropriate Eclipse projects. Do this even if you are planning on using Intellij IDEA.
- If you use Eclipse, open Eclipse, and navigate to File -> Import -> General -> Existing Projects into Workspace. Navigate to and select theprojectssubdirectory, and check your mod project, and optionally the clean (unmodified) project too.
- Otherwise, open Intellij IDEA and import the Eclipse project. From 3 available projects choose one in projects/carpetmod
Once you have setup the project, you should see a file structure which looks something like this:
- src/main/java This is where all of the MINECRAFT classes go, i.e. classes which you may or may not have modified, but no classes you have added.
- src/main/resources Similar to src/main/java except for non-java files.
- main-java This is where all of the MOD classes go, i.e. the classes which you have added.
- main-resources Similar to main-java except for non-java files.
From outside Eclipse, the file structure looks a little different. However, you should avoid editing these files from outside your IDE of choice:
- src/main/java The MOD classes
- src/main/resources The MOD resources
- patches Patches your mod has made to the MINECRAFT classes, which can be pushed to public repositories
- projects/<modname>/src/main/java * The MINECRAFT classes
- projects/<modname>/src/main/resources * The MINECRAFT resources
- projects/clean/src/main/java * The unmodified MINECRAFT classes
- projects/clean/src/main/resources * The unmodified MINECRAFT resources
* = ignored by git
- You should be able to run Minecraft directly from within the IDE.
- Every time you checkout a branch which has changed files in the patchesdirectory, you need to rungradlew setupagain to update the code insrc/main/javainside the IDE. This will not try to decompile again like it did the first time, so won't take long. This will overwrite your local changes.
- Every time you make changes to MINECRAFT classes and want to push to the public repo, you need to run gradlew genPatchesto update the patch files in thepatchesdirectory. This takes a few seconds.
- When you are ready to create a release, run gradlew createRelease. This may take longer than the other tasks because it is recompiling the code. Once it is done, your releases can be found in thebuild/distributionsdirectory. It includes patches for server jar as well as standalone client jar
Accessible in conf/settings.json. Beware that changes to this may significanly modify the carpetmod patches so only do it if you know what your are doing or you want to keep your own fork
- modnamethe name of your mod.
- modversionthe version your mod is on.
- mcpconfigthe MCPConfig version you are using.
- mappingsthe MCP mappings you are using.
- mcversionthe Minecraft version.
- pipeline, either- joined,- clientor- server- whether your mod is to be a client-side-only or server-side-only mod, or to be both and share the same codebase.
- clientmainthe main class on the client.
- servermainthe main class on the server.
- reformatwhether to run Artistic Style on the code to reformat it. Makes the build process a little slower but does mean you can change the formatting options with- conf/astyle.cfg.
- customsrgThe custom tsrg file inside the- conf/folder, to override the one in the MCPConfig distribution, used to deobfuscate even newer Minecraft versions.
1.13 modding is still in its infancy, and there are already known bugs that occur in the decompiled code which do not occur in vanilla. If you care about maintaining vanilla behaviour, then whenever making a change which may modify a certain vanilla class, make sure to weigh up the benefit of modifying said class against the risk that there might be a decompile bug in the class. This situation is constantly improving as 1.13 modding matures, but for now you can at least minimize the effect by distributing as few modified classes as possible.