diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 4e0d9a5..d5cc731 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,33 +1,31 @@ name: build - -on: [push, pull_request] +on: [ pull_request, push ] jobs: build: - runs-on: ubuntu-latest + strategy: + matrix: + java: [ 17 ] + os: [ ubuntu-22.04 ] + runs-on: ${{ matrix.os }} steps: - - name: Checkout sources - uses: actions/checkout@v2 - - - name: Set up JDK 17 - uses: actions/setup-java@v1 - with: - java-version: 17 - - - name: Cache Brachyura directory - uses: actions/cache@v2 - with: - path: | - .brachyura - ~/.brachyura - key: ${{ runner.os }}-brachyura-${{ hashFiles('**/Buildscript.java') }} - restore-keys: ${{ runner.os }}-brachyura - - - name: Build with Brachyura - run: java -jar brachyura-bootstrap-0.jar build - - - name: Upload artifacts - uses: actions/upload-artifact@v3 - with: - name: artifacts - path: build/libs \ No newline at end of file + - name: Checkout repository + uses: actions/checkout@v3 + - name: Validate gradle wrapper + uses: gradle/wrapper-validation-action@v1 + - name: Setup JDK ${{ matrix.java }} + uses: actions/setup-java@v3 + with: + java-version: ${{ matrix.java }} + distribution: 'microsoft' + - name: Make gradle wrapper executable + if: ${{ runner.os != 'Windows' }} + run: chmod +x ./gradlew + - name: build + run: ./gradlew build + - name: Capture build artifacts + if: ${{ runner.os == 'Linux' && matrix.java == '17' }} + uses: actions/upload-artifact@v3 + with: + name: Artifacts + path: build/libs/ diff --git a/.github/workflows/publish-curseforge.yml b/.github/workflows/publish-curseforge.yml index 71e5960..f86d589 100644 --- a/.github/workflows/publish-curseforge.yml +++ b/.github/workflows/publish-curseforge.yml @@ -11,46 +11,46 @@ jobs: steps: - name: Checkout sources uses: actions/checkout@v2 - - name: Set up JDK 17 uses: actions/setup-java@v1 with: java-version: 17 - - - name: Cache Brachyura directory - uses: actions/cache@v2 + - name: Change wrapper permissions + run: chmod +x ./gradlew + - name: Build artifacts + run: ./gradlew build + - uses: BrycensRanch/read-properties-action@v1 + id: gradle_props with: - path: | - .brachyura - ~/.brachyura - key: ${{ runner.os }}-brachyura-${{ hashFiles('**/Buildscript.java') }} - restore-keys: ${{ runner.os }}-brachyura - - - name: Build with Brachyura - run: java -jar brachyura-bootstrap-0.jar build - - - name: Publish artifacts to CurseForge - uses: Kir-Antipov/mc-publish@v3.3 + file: gradle.properties + all: true + - name: Publish fabric artifacts + uses: Kir-Antipov/mc-publish@v3.3.0 with: curseforge-id: 521126 curseforge-token: ${{ secrets.CURSEFORGE_TOKEN }} - files: build/libs/!(*-@(dev|sources)).jar + files: | + build/libs/${{ steps.gradle_props.outputs.archives_base_name }}-${{ github.event.release.tag_name }}.jar + build/libs/${{ steps.gradle_props.outputs.archives_base_name }}-${{ github.event.release.tag_name }}-sources.jar + + version: ${{ github.event.release.tag_name }} version-type: beta loaders: | fabric quilt - + + game-versions: ${{ steps.gradle_props.outputs.minecraft_version_range }} game-version-filter: releases - + dependencies: | - fabric-api(required){modrinth:P7dR8mSH}{curseforge:306612}#(ignore:github) - cloth-config(required){modrinth:9s6osm5g}{curseforge:348521}#(ignore:github) + fabric-api + cloth-config java: | 17 retry-attempts: 2 retry-delay: 10000 - fail-mode: fail + fail-mode: skip \ No newline at end of file diff --git a/.github/workflows/publish-github.yml b/.github/workflows/publish-github.yml index a30bde5..3bf4157 100644 --- a/.github/workflows/publish-github.yml +++ b/.github/workflows/publish-github.yml @@ -11,26 +11,16 @@ jobs: steps: - name: Checkout sources uses: actions/checkout@v2 - - name: Set up JDK 17 uses: actions/setup-java@v1 with: java-version: 17 - - - name: Cache Brachyura directory - uses: actions/cache@v2 + - name: Change wrapper permissions + run: chmod +x ./gradlew + - name: Build artifacts + run: ./gradlew build + - name: Upload assets to GitHub + uses: AButler/upload-release-assets@v3.0 with: - path: | - .brachyura - ~/.brachyura - key: ${{ runner.os }}-brachyura-${{ hashFiles('**/Buildscript.java') }} - restore-keys: ${{ runner.os }}-brachyura - - - name: Build with Brachyura - run: java -jar brachyura-bootstrap-0.jar build - - - name: Publish artifacts to GitHub - uses: AButler/upload-release-assets@v2.0 - with: - files: 'build/libs/*' - repo-token: ${{ secrets.GH_TOKEN }} \ No newline at end of file + files: "build/libs/*" + repo-token: ${{ secrets.GH_TOKEN }} diff --git a/.github/workflows/publish-modrinth.yml b/.github/workflows/publish-modrinth.yml index c73bba1..dd064dd 100644 --- a/.github/workflows/publish-modrinth.yml +++ b/.github/workflows/publish-modrinth.yml @@ -11,46 +11,46 @@ jobs: steps: - name: Checkout sources uses: actions/checkout@v2 - - name: Set up JDK 17 uses: actions/setup-java@v1 with: java-version: 17 - - - name: Cache Brachyura directory - uses: actions/cache@v2 + - name: Change wrapper permissions + run: chmod +x ./gradlew + - name: Build artifacts + run: ./gradlew build + - uses: BrycensRanch/read-properties-action@v1 + id: gradle_props with: - path: | - .brachyura - ~/.brachyura - key: ${{ runner.os }}-brachyura-${{ hashFiles('**/Buildscript.java') }} - restore-keys: ${{ runner.os }}-brachyura - - - name: Build with Brachyura - run: java -jar brachyura-bootstrap-0.jar build - - - name: Publish artifacts to Modrinth - uses: Kir-Antipov/mc-publish@v3.3 + file: gradle.properties + all: true + - name: Publish fabric artifacts + uses: Kir-Antipov/mc-publish@v3.3.0 with: modrinth-id: rI0hvYcd modrinth-token: ${{ secrets.MODRINTH_TOKEN }} - files: build/libs/!(*-@(dev|sources)).jar + files: | + build/libs/${{ steps.gradle_props.outputs.archives_base_name }}-${{ github.event.release.tag_name }}.jar + build/libs/${{ steps.gradle_props.outputs.archives_base_name }}-${{ github.event.release.tag_name }}-sources.jar + + version: ${{ github.event.release.tag_name }} version-type: beta loaders: | fabric quilt - - game-version-filter: releases + game-versions: ${{ steps.gradle_props.outputs.minecraft_version_range }} + game-version-filter: releases + dependencies: | - fabric-api(required){modrinth:P7dR8mSH}{curseforge:306612}#(ignore:github) - cloth-config(required){modrinth:9s6osm5g}{curseforge:348521}#(ignore:github) + fabric-api + cloth-config java: | 17 retry-attempts: 2 retry-delay: 10000 - fail-mode: fail + fail-mode: skip \ No newline at end of file diff --git a/.gitignore b/.gitignore index 4010a36..09cd281 100644 --- a/.gitignore +++ b/.gitignore @@ -5,11 +5,6 @@ build/ out/ classes/ -# brachyura - -.brachyura/ -buildscript/build/ - # eclipse *.launch @@ -36,7 +31,3 @@ bin/ # fabric run/ - -# netbeans - -netbeans/ \ No newline at end of file diff --git a/README.md b/README.md index f22dfa8..edeff25 100644 --- a/README.md +++ b/README.md @@ -15,8 +15,3 @@ to your Minecraft world. Expect particles collection expanding with the mod upda You can configure the mod by editing visuality.json in the config folder of your Minecraft directory or simply through ModMenu integration. - -## Development -Unlike any other projects Visuality uses [brachyura build tool](https://github.com/CoolCrabs/brachyura), to set up development environment close you IDE and open -a command prompt or terminal, run `java -jar brachyura-bootstrap-0.jar idea`, replace `idea` with `jdt` if you use VS Code -or Eclipse, and `netbeans` if its Netbeans, reopen the IDE and allow it to import the project. diff --git a/brachyura-bootstrap-0.jar b/brachyura-bootstrap-0.jar deleted file mode 100644 index ffb6fd8..0000000 Binary files a/brachyura-bootstrap-0.jar and /dev/null differ diff --git a/brachyurabootstrapconf.txt b/brachyurabootstrapconf.txt deleted file mode 100644 index cc623e4..0000000 --- a/brachyurabootstrapconf.txt +++ /dev/null @@ -1,45 +0,0 @@ -0 -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/brachyura-0.95.jar A3FF7412634D7A18EE3A0F59915AEF3B38EC7141 brachyura-0.95.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/brachyura-0.95-sources.jar 5B6FAE353547475B93C22247D20D4538DC9A80DF brachyura-0.95-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/trieharder-0.2.0.jar FB5F8770BC368C19197C6B910B72B4676450CBD6 trieharder-0.2.0.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/trieharder-0.2.0-sources.jar 9ED36D104B9C46912B3149B3BA3A9599FADD4CB8 trieharder-0.2.0-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/recombobulator-0.5.jar 9DFD6CB020B47B21A5C6CF87A08AB4FCBC78E8CC recombobulator-0.5.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/recombobulator-0.5-sources.jar 643FD92F5E8E61850C57F94F57A0C12E3FC18E87 recombobulator-0.5-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/fernutil-0.2.jar C076DA44E53AEADFBC8859196501E7147D05947D fernutil-0.2.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/fernutil-0.2-sources.jar 24CDC2628AF10D0ABD04C5BC5533AF7B0A0DB028 fernutil-0.2-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/fabricmerge-0.2.jar 8C79C6FF9AC59B60C32E982BC5E9B1A8DD2E9A7B fabricmerge-0.2.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/fabricmerge-0.2-sources.jar D121EEBE5DC3137511BDCC94B3F2B1B7A3611A33 fabricmerge-0.2-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/cfr-0.6.jar 488B145D4778522120867D09DF6DB64A2AB5A730 cfr-0.6.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/cfr-0.6-sources.jar D113E51E5310F69AD04426A2A6DC3340C4CB46A9 cfr-0.6-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/brachyura-mixin-compile-extensions-0.10.jar 8AE63316B2E74D0BC82F262D78810E4AB08150EA brachyura-mixin-compile-extensions-0.10.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/brachyura-mixin-compile-extensions-0.10-sources.jar E9C5A1891737FF7E52CC40D44FF14A98DD1575BD brachyura-mixin-compile-extensions-0.10-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/access-widener-0.2.jar 7B1DBF869FCC2D589B4A96141368021394AAF73D access-widener-0.2.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/access-widener-0.2-sources.jar 1F41A4474EC149C29C8FFADFA9D89D9ADFAC3C73 access-widener-0.2-sources.jar false -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/brachyura-minecraft-0.4.jar 6C326E710CA7E5A6D5B2F4FF261764E82234659A brachyura-minecraft-0.4.jar true -https://github.com/CoolCrabs/brachyura/releases/download/v_ea8cb5cf49353d86238a6adaedab05ddd60a66d9/brachyura-minecraft-0.4-sources.jar A3B8AA9A4E54E9D5C79ADCC9C3E1591C6CD414F5 brachyura-minecraft-0.4-sources.jar false -https://repo.maven.apache.org/maven2/org/jetbrains/annotations/23.0.0/annotations-23.0.0.jar 8cc20c07506ec18e0834947b84a864bfc094484e annotations-23.0.0.jar true -https://repo.maven.apache.org/maven2/org/jetbrains/annotations/23.0.0/annotations-23.0.0-sources.jar ca5088d615accaabd2aa956b10b236a4e75cfccb annotations-23.0.0-sources.jar false -https://repo.maven.apache.org/maven2/com/google/code/gson/gson/2.9.0/gson-2.9.0.jar 8a1167e089096758b49f9b34066ef98b2f4b37aa gson-2.9.0.jar true -https://repo.maven.apache.org/maven2/com/google/code/gson/gson/2.9.0/gson-2.9.0-sources.jar 83f964c0d36cda6b05269fdd43abd0f553a17c84 gson-2.9.0-sources.jar false -https://repo.maven.apache.org/maven2/org/tinylog/tinylog-api/2.4.1/tinylog-api-2.4.1.jar 7135fec9e01c4c33e527e1bd9a246889e940efef tinylog-api-2.4.1.jar true -https://repo.maven.apache.org/maven2/org/tinylog/tinylog-api/2.4.1/tinylog-api-2.4.1-sources.jar a7ab25888ab7ff19850bccf98dbbe8dba29abe13 tinylog-api-2.4.1-sources.jar false -https://repo.maven.apache.org/maven2/org/tinylog/tinylog-impl/2.4.1/tinylog-impl-2.4.1.jar c91d9059cd6b73f3965ce218357c392c4c57118b tinylog-impl-2.4.1.jar true -https://repo.maven.apache.org/maven2/org/tinylog/tinylog-impl/2.4.1/tinylog-impl-2.4.1-sources.jar c4e012893e832d1803a171265465e2a3227270a7 tinylog-impl-2.4.1-sources.jar false -https://repo.maven.apache.org/maven2/org/ow2/asm/asm/9.3/asm-9.3.jar 8e6300ef51c1d801a7ed62d07cd221aca3a90640 asm-9.3.jar true -https://repo.maven.apache.org/maven2/org/ow2/asm/asm/9.3/asm-9.3-sources.jar ce26e415ccafa10c6624a07bdb38d969110f568f asm-9.3-sources.jar false -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-analysis/9.3/asm-analysis-9.3.jar 4b071f211b37c38e0e9f5998550197c8593f6ad8 asm-analysis-9.3.jar true -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-analysis/9.3/asm-analysis-9.3-sources.jar fbcbbfcd8c350fea66dd36e63b1e118d4ab3370c asm-analysis-9.3-sources.jar false -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-commons/9.3/asm-commons-9.3.jar 1f2a432d1212f5c352ae607d7b61dcae20c20af5 asm-commons-9.3.jar true -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-commons/9.3/asm-commons-9.3-sources.jar 1692e21847cf3db0b24e1938553cab84f50bf03d asm-commons-9.3-sources.jar false -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-tree/9.3/asm-tree-9.3.jar 78d2ecd61318b5a58cd04fb237636c0e86b77d97 asm-tree-9.3.jar true -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-tree/9.3/asm-tree-9.3-sources.jar 0cc1987e5e291659c366c4b9be35d105d40a518a asm-tree-9.3-sources.jar false -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-util/9.3/asm-util-9.3.jar 9595bc05510d0bd4b610188b77333fe4851a1975 asm-util-9.3.jar true -https://repo.maven.apache.org/maven2/org/ow2/asm/asm-util/9.3/asm-util-9.3-sources.jar 7a969dd37607523cfd3b9d2ef1a3e78882bfe647 asm-util-9.3-sources.jar false -https://repo.maven.apache.org/maven2/it/unimi/dsi/fastutil/8.5.8/fastutil-8.5.8.jar 8077f8d41f53e5b37ee75861596c574457824f50 fastutil-8.5.8.jar true -https://repo.maven.apache.org/maven2/it/unimi/dsi/fastutil/8.5.8/fastutil-8.5.8-sources.jar 05c9e963814cfd4a1b038ba353837b8b3792857c fastutil-8.5.8-sources.jar false -https://maven.fabricmc.net/net/fabricmc/mapping-io/0.3.0/mapping-io-0.3.0.jar f7c41de27b01e622ba85f72794012bf7447e4156 mapping-io-0.3.0.jar true -https://maven.fabricmc.net/net/fabricmc/mapping-io/0.3.0/mapping-io-0.3.0-sources.jar 7002ec63184af7dfa48b68595be6388bc847f5b6 mapping-io-0.3.0-sources.jar false -https://repo1.maven.org/maven2/org/apache/maven/maven-model/3.8.6/maven-model-3.8.6.jar 8ad31867c493c63ac60a3fa42356a72d20f8457b maven-model-3.8.6.jar true -https://repo1.maven.org/maven2/org/apache/maven/maven-model/3.8.6/maven-model-3.8.6-sources.jar 3f2471220d4a7124aee2bbe9ff801b83c4c32ef6 maven-model-3.8.6-sources.jar false -https://repo1.maven.org/maven2/org/codehaus/plexus/plexus-utils/3.5.0/plexus-utils-3.5.0.jar ff9f0881396a06b31ff548048256e9a7c8f1207a plexus-utils-3.5.0.jar true -https://repo1.maven.org/maven2/org/codehaus/plexus/plexus-utils/3.5.0/plexus-utils-3.5.0-sources.jar 3dea705bdf7a667bc72b982cab5c32610fc1774a plexus-utils-3.5.0-sources.jar false \ No newline at end of file diff --git a/build.gradle b/build.gradle new file mode 100644 index 0000000..9328256 --- /dev/null +++ b/build.gradle @@ -0,0 +1,56 @@ +plugins { + id "fabric-loom" version "1.6-SNAPSHOT" +} + +version = project.mod_version +group = project.maven_group + +repositories { + maven { url "https://maven.shedaniel.me/" } //cloth-config + maven { url "https://maven.terraformersmc.com" } //modmenu +} + +dependencies { + minecraft "com.mojang:minecraft:${project.minecraft_version}" + mappings "net.fabricmc:yarn:${project.yarn_mappings}:v2" + + modImplementation "net.fabricmc:fabric-loader:${project.fabric_loader}" + modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_api}" + + modApi("me.shedaniel.cloth:cloth-config-fabric:${project.cloth_config}") { exclude(group: "net.fabricmc.fabric-api") } + modApi "com.terraformersmc:modmenu:${project.modmenu_version}" +} + +base { + archivesName = project.archives_base_name +} + +processResources { + def expandProps = [ + "version": rootProject.mod_version, + "minecraft_version_range": rootProject.minecraft_version_range, + ] + + filesMatching(["fabric.mod.json"]) { + expand expandProps + } + + inputs.properties(expandProps) +} + +tasks.withType(JavaCompile).configureEach { + it.options.encoding = "UTF-8" + it.options.release = 17 +} + +java { + sourceCompatibility = JavaVersion.VERSION_17 + targetCompatibility = JavaVersion.VERSION_17 + withSourcesJar() +} + +jar { + from("LICENSE") { + rename { "${it}_${project.base.archivesName.get()}"} + } +} diff --git a/buildscript/buildscript.properties b/buildscript/buildscript.properties deleted file mode 100644 index 605cfbd..0000000 --- a/buildscript/buildscript.properties +++ /dev/null @@ -1,14 +0,0 @@ -# Mod Properties -name = visuality -modVersion = 0.7.3+1.20.4 -javaVersion = 17 - -# Dependencies -minecraftVersion = 1.20.3 -yarnMappings = 1.20.3+build.1 -fabricLoader = 0.14.23 -vineflower = 1.9.3 - -fabricApi = 0.91.1+1.20.3 -clothConfig = 12.0.109 -modmenu = 9.0.0-pre.1 diff --git a/buildscript/src/main/java/Buildscript.java b/buildscript/src/main/java/Buildscript.java deleted file mode 100644 index 47dcefc..0000000 --- a/buildscript/src/main/java/Buildscript.java +++ /dev/null @@ -1,117 +0,0 @@ -import io.github.coolcrabs.brachyura.decompiler.BrachyuraDecompiler; -import io.github.coolcrabs.brachyura.decompiler.fernflower.FernflowerDecompiler; -import io.github.coolcrabs.brachyura.fabric.*; -import io.github.coolcrabs.brachyura.fabric.FabricContext.ModDependencyCollector; -import io.github.coolcrabs.brachyura.maven.Maven; -import io.github.coolcrabs.brachyura.maven.MavenId; -import io.github.coolcrabs.brachyura.minecraft.Minecraft; -import io.github.coolcrabs.brachyura.minecraft.VersionMeta; -import io.github.coolcrabs.brachyura.processing.ProcessorChain; -import net.fabricmc.mappingio.tree.MappingTree; -import org.apache.maven.model.Model; -import org.apache.maven.model.io.xpp3.MavenXpp3Reader; - -import java.io.InputStreamReader; -import java.net.URL; -import java.net.URLConnection; -import java.io.FileInputStream; -import java.io.InputStream; -import java.util.Properties; - -import static io.github.coolcrabs.brachyura.fabric.FabricContext.ModDependencyFlag.RUNTIME; -import static io.github.coolcrabs.brachyura.fabric.FabricContext.ModDependencyFlag.COMPILE; - -public class Buildscript extends SimpleFabricProject { - public Properties properties = null; - - @Override - public String getModId() { - return this.getProperties().getProperty("name"); - } - - @Override - public String getVersion() { - return this.getProperties().getProperty("modVersion"); - } - - @Override - public VersionMeta createMcVersion() { - return Minecraft.getVersion(this.getProperties().getProperty("minecraftVersion")); - } - - @Override - public MappingTree createMappings() { - return Yarn.ofMaven(FabricMaven.URL, FabricMaven.yarn(this.getProperties().getProperty("yarnMappings"))).tree; - } - - @Override - public FabricLoader getLoader() { - return new FabricLoader(FabricMaven.URL, FabricMaven.loader(this.getProperties().getProperty("fabricLoader"))); - } - - @Override - public void getModDependencies(ModDependencyCollector d) { - addFabricModules(d); - - d.addMaven("https://maven.shedaniel.me", new MavenId("me.shedaniel.cloth", "cloth-config-fabric", this.getProperties().getProperty("clothConfig")), RUNTIME, COMPILE); - d.addMaven("https://maven.shedaniel.me", new MavenId("me.shedaniel.cloth", "basic-math", "0.6.1"), RUNTIME, COMPILE); - - // Compatibility - d.addMaven("https://maven.terraformersmc.com", new MavenId("com.terraformersmc", "modmenu", this.getProperties().getProperty("modmenu")), RUNTIME, COMPILE); - } - - public void addFabricModules(ModDependencyCollector d) { - String fabricApi = this.getProperties().getProperty("fabricApi"); - d.addMaven(FabricMaven.URL, new MavenId(FabricMaven.GROUP_ID + ".fabric-api", "fabric-api", fabricApi), RUNTIME, COMPILE); - try { - String temp = "https://maven.fabricmc.net/net/fabricmc/fabric-api/fabric-api/%version%/fabric-api-%version%.pom"; - String pom = temp.replaceAll("%version%", fabricApi); - URL url = new URL(pom); - URLConnection request = url.openConnection(); - request.connect(); - InputStreamReader isReader = new InputStreamReader(request.getInputStream()); - MavenXpp3Reader reader = new MavenXpp3Reader(); - Model model = reader.read(isReader); - - model.getDependencies().forEach(dependency -> { - var id = dependency.getArtifactId(); - var ver = dependency.getVersion(); - d.addMaven(FabricMaven.URL, new MavenId(FabricMaven.GROUP_ID + ".fabric-api", id, ver), RUNTIME, COMPILE); - }); - - } - catch(Exception e) { - System.out.println("Failed to add fabric modules due to an exception:\n" + e); - } - } - - public Properties getProperties() { - if(this.properties == null) { - try (InputStream input = new FileInputStream(getProjectDir().resolve("buildscript").resolve("buildscript.properties").toFile())) { - Properties prop = new Properties(); - prop.load(input); - this.properties = prop; - } - catch (Exception e) { - System.out.println("Failed to read buildscript.properties due to an exception:\n" + e); - this.properties = new Properties(); - } - } - return this.properties; - } - - @Override - public int getJavaVersion() { - return 17; - } - - @Override - public BrachyuraDecompiler decompiler() { - return new FernflowerDecompiler(Maven.getMavenJarDep("https://repo1.maven.org/maven2/", new MavenId("org.vineflower", "vineflower", this.getProperties().getProperty("vineflower")))); - } - - @Override - public ProcessorChain resourcesProcessingChain() { - return new ProcessorChain(super.resourcesProcessingChain(), new FmjVersionFixer(this)); - } -} diff --git a/buildscript/src/main/java/FmjVersionFixer.java b/buildscript/src/main/java/FmjVersionFixer.java deleted file mode 100644 index dae7f6f..0000000 --- a/buildscript/src/main/java/FmjVersionFixer.java +++ /dev/null @@ -1,40 +0,0 @@ -import com.google.gson.Gson; -import com.google.gson.GsonBuilder; -import com.google.gson.JsonObject; -import io.github.coolcrabs.brachyura.processing.ProcessingEntry; -import io.github.coolcrabs.brachyura.processing.ProcessingSink; -import io.github.coolcrabs.brachyura.processing.Processor; -import io.github.coolcrabs.brachyura.util.GsonUtil; - -import java.io.BufferedReader; -import java.io.IOException; -import java.io.InputStreamReader; -import java.nio.charset.StandardCharsets; -import java.util.Collection; - -public class FmjVersionFixer implements Processor { - private final Buildscript parent; - - public FmjVersionFixer(Buildscript parent) { - this.parent = parent; - } - - @Override - public void process(Collection inputs, ProcessingSink sink) throws IOException { - for (ProcessingEntry e : inputs) { - if ("fabric.mod.json".equals(e.id.path)) { - Gson gson = new GsonBuilder().setPrettyPrinting().setLenient().create(); - JsonObject fabricModJson; - try (BufferedReader reader = new BufferedReader(new InputStreamReader(e.in.get(), StandardCharsets.UTF_8))) { - fabricModJson = gson.fromJson(reader, JsonObject.class); - } - - fabricModJson.addProperty("version", parent.getVersion()); - - sink.sink(() -> GsonUtil.toIs(fabricModJson, gson), e.id); - } else { - sink.sink(e.in, e.id); - } - } - } -} \ No newline at end of file diff --git a/gradle.properties b/gradle.properties new file mode 100644 index 0000000..1103a9e --- /dev/null +++ b/gradle.properties @@ -0,0 +1,18 @@ +# Done to increase the memory available to gradle. +org.gradle.jvmargs = -Xmx2G +org.gradle.parallel = true + +# Mod Properties +mod_version = 0.7.4+1.20.4 +maven_group = ru.pinkgoosik +archives_base_name = visuality +minecraft_version_range = >=1.20.3 <1.21 + +# Dependencies | Check these on https://fabricmc.net/develop +minecraft_version = 1.20.4 +yarn_mappings = 1.20.4+build.3 +fabric_loader = 0.15.7 +fabric_api = 0.96.11+1.20.4 + +cloth_config = 13.0.121 +modmenu_version = 9.0.0 diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000..249e583 Binary files /dev/null and b/gradle/wrapper/gradle-wrapper.jar differ diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties new file mode 100644 index 0000000..dd93a87 --- /dev/null +++ b/gradle/wrapper/gradle-wrapper.properties @@ -0,0 +1,6 @@ +distributionBase=GRADLE_USER_HOME +distributionPath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-bin.zip +networkTimeout=10000 +zipStoreBase=GRADLE_USER_HOME +zipStorePath=wrapper/dists \ No newline at end of file diff --git a/gradlew b/gradlew new file mode 100644 index 0000000..a69d9cb --- /dev/null +++ b/gradlew @@ -0,0 +1,240 @@ +#!/bin/sh + +# +# Copyright © 2015-2021 the original authors. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +############################################################################## +# +# Gradle start up script for POSIX generated by Gradle. +# +# Important for running: +# +# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is +# noncompliant, but you have some other compliant shell such as ksh or +# bash, then to run this script, type that shell name before the whole +# command line, like: +# +# ksh Gradle +# +# Busybox and similar reduced shells will NOT work, because this script +# requires all of these POSIX shell features: +# * functions; +# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», +# «${var#prefix}», «${var%suffix}», and «$( cmd )»; +# * compound commands having a testable exit status, especially «case»; +# * various built-in commands including «command», «set», and «ulimit». +# +# Important for patching: +# +# (2) This script targets any POSIX shell, so it avoids extensions provided +# by Bash, Ksh, etc; in particular arrays are avoided. +# +# The "traditional" practice of packing multiple parameters into a +# space-separated string is a well documented source of bugs and security +# problems, so this is (mostly) avoided, by progressively accumulating +# options in "$@", and eventually passing that to Java. +# +# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, +# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; +# see the in-line comments for details. +# +# There are tweaks for specific operating systems such as AIX, CygWin, +# Darwin, MinGW, and NonStop. +# +# (3) This script is generated from the Groovy template +# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt +# within the Gradle project. +# +# You can find Gradle at https://github.com/gradle/gradle/. +# +############################################################################## + +# Attempt to set APP_HOME + +# Resolve links: $0 may be a link +app_path=$0 + +# Need this for daisy-chained symlinks. +while + APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path + [ -h "$app_path" ] +do + ls=$( ls -ld "$app_path" ) + link=${ls#*' -> '} + case $link in #( + /*) app_path=$link ;; #( + *) app_path=$APP_HOME$link ;; + esac +done + +APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit + +APP_NAME="Gradle" +APP_BASE_NAME=${0##*/} + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' + +# Use the maximum available, or set MAX_FD != -1 to use that value. +MAX_FD=maximum + +warn () { + echo "$*" +} >&2 + +die () { + echo + echo "$*" + echo + exit 1 +} >&2 + +# OS specific support (must be 'true' or 'false'). +cygwin=false +msys=false +darwin=false +nonstop=false +case "$( uname )" in #( + CYGWIN* ) cygwin=true ;; #( + Darwin* ) darwin=true ;; #( + MSYS* | MINGW* ) msys=true ;; #( + NONSTOP* ) nonstop=true ;; +esac + +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + + +# Determine the Java command to use to start the JVM. +if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD=$JAVA_HOME/jre/sh/java + else + JAVACMD=$JAVA_HOME/bin/java + fi + if [ ! -x "$JAVACMD" ] ; then + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +else + JAVACMD=java + which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." +fi + +# Increase the maximum file descriptors if we can. +if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then + case $MAX_FD in #( + max*) + MAX_FD=$( ulimit -H -n ) || + warn "Could not query maximum file descriptor limit" + esac + case $MAX_FD in #( + '' | soft) :;; #( + *) + ulimit -n "$MAX_FD" || + warn "Could not set maximum file descriptor limit to $MAX_FD" + esac +fi + +# Collect all arguments for the java command, stacking in reverse order: +# * args from the command line +# * the main class name +# * -classpath +# * -D...appname settings +# * --module-path (only if needed) +# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. + +# For Cygwin or MSYS, switch paths to Windows format before running java +if "$cygwin" || "$msys" ; then + APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) + CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) + + JAVACMD=$( cygpath --unix "$JAVACMD" ) + + # Now convert the arguments - kludge to limit ourselves to /bin/sh + for arg do + if + case $arg in #( + -*) false ;; # don't mess with options #( + /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath + [ -e "$t" ] ;; #( + *) false ;; + esac + then + arg=$( cygpath --path --ignore --mixed "$arg" ) + fi + # Roll the args list around exactly as many times as the number of + # args, so each arg winds up back in the position where it started, but + # possibly modified. + # + # NB: a `for` loop captures its iteration list before it begins, so + # changing the positional parameters here affects neither the number of + # iterations, nor the values presented in `arg`. + shift # remove old arg + set -- "$@" "$arg" # push replacement arg + done +fi + +# Collect all arguments for the java command; +# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of +# shell script including quotes and variable substitutions, so put them in +# double quotes to make sure that they get re-expanded; and +# * put everything else in single quotes, so that it's not re-expanded. + +set -- \ + "-Dorg.gradle.appname=$APP_BASE_NAME" \ + -classpath "$CLASSPATH" \ + org.gradle.wrapper.GradleWrapperMain \ + "$@" + +# Stop when "xargs" is not available. +if ! command -v xargs >/dev/null 2>&1 +then + die "xargs is not available" +fi + +# Use "xargs" to parse quoted args. +# +# With -n1 it outputs one arg per line, with the quotes and backslashes removed. +# +# In Bash we could simply go: +# +# readarray ARGS < <( xargs -n1 <<<"$var" ) && +# set -- "${ARGS[@]}" "$@" +# +# but POSIX shell has neither arrays nor command substitution, so instead we +# post-process each arg (as a line of input to sed) to backslash-escape any +# character that might be a shell metacharacter, then use eval to reverse +# that process (while maintaining the separation between arguments), and wrap +# the whole thing up as a single "set" statement. +# +# This will of course break if any of these variables contains a newline or +# an unmatched quote. +# + +eval "set -- $( + printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | + xargs -n1 | + sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | + tr '\n' ' ' + )" '"$@"' + +exec "$JAVACMD" "$@" diff --git a/gradlew.bat b/gradlew.bat new file mode 100644 index 0000000..f127cfd --- /dev/null +++ b/gradlew.bat @@ -0,0 +1,91 @@ +@rem +@rem Copyright 2015 the original author or authors. +@rem +@rem Licensed under the Apache License, Version 2.0 (the "License"); +@rem you may not use this file except in compliance with the License. +@rem You may obtain a copy of the License at +@rem +@rem https://www.apache.org/licenses/LICENSE-2.0 +@rem +@rem Unless required by applicable law or agreed to in writing, software +@rem distributed under the License is distributed on an "AS IS" BASIS, +@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +@rem See the License for the specific language governing permissions and +@rem limitations under the License. +@rem + +@if "%DEBUG%"=="" @echo off +@rem ########################################################################## +@rem +@rem Gradle startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%"=="" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Resolve any "." and ".." in APP_HOME to make it shorter. +for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi + +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" + +@rem Find java.exe +if defined JAVA_HOME goto findJavaFromJavaHome + +set JAVA_EXE=java.exe +%JAVA_EXE% -version >NUL 2>&1 +if %ERRORLEVEL% equ 0 goto execute + +echo. +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. +echo. +echo Please set the JAVA_HOME variable in your environment to match the +echo location of your Java installation. + +goto fail + +:findJavaFromJavaHome +set JAVA_HOME=%JAVA_HOME:"=% +set JAVA_EXE=%JAVA_HOME%/bin/java.exe + +if exist "%JAVA_EXE%" goto execute + +echo. +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% +echo. +echo Please set the JAVA_HOME variable in your environment to match the +echo location of your Java installation. + +goto fail + +:execute +@rem Setup the command line + +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + + +@rem Execute Gradle +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* + +:end +@rem End local scope for the variables with windows NT shell +if %ERRORLEVEL% equ 0 goto mainEnd + +:fail +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of +rem the _cmd.exe /c_ return code! +set EXIT_CODE=%ERRORLEVEL% +if %EXIT_CODE% equ 0 set EXIT_CODE=1 +if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% +exit /b %EXIT_CODE% + +:mainEnd +if "%OS%"=="Windows_NT" endlocal + +:omega diff --git a/settings.gradle b/settings.gradle new file mode 100644 index 0000000..cf0fb6c --- /dev/null +++ b/settings.gradle @@ -0,0 +1,7 @@ +pluginManagement { + repositories { + mavenCentral() + gradlePluginPortal() + maven { url "https://maven.fabricmc.net" } + } +} diff --git a/src/main/resources/META-INF/MANIFEST.MF b/src/main/resources/META-INF/MANIFEST.MF deleted file mode 100644 index b577156..0000000 --- a/src/main/resources/META-INF/MANIFEST.MF +++ /dev/null @@ -1,2 +0,0 @@ -Manifest-Version: 1.0 -Fabric-Mapping-Namespace: intermediary diff --git a/src/main/resources/fabric.mod.json b/src/main/resources/fabric.mod.json index 67b9761..d794fe9 100644 --- a/src/main/resources/fabric.mod.json +++ b/src/main/resources/fabric.mod.json @@ -1,7 +1,7 @@ { "schemaVersion": 1, "id": "visuality", - "version": "dev", + "version": "${version}", "name": "Visuality", "description": "Little visual improvements by adding a bunch of new particles.", "authors": [ @@ -37,7 +37,7 @@ "fabricloader": "*", "fabric-api": "*", "cloth-config": "*", - "minecraft": ">=1.20.3 <1.21", + "minecraft": "${minecraft_version_range}", "java": ">=17" } }