diff options
Diffstat (limited to 'src/main')
4 files changed, 100 insertions, 0 deletions
diff --git a/src/main/java/net/fabricmc/loom/api/LoomGradleExtensionAPI.java b/src/main/java/net/fabricmc/loom/api/LoomGradleExtensionAPI.java index 36809280..0acb6da0 100644 --- a/src/main/java/net/fabricmc/loom/api/LoomGradleExtensionAPI.java +++ b/src/main/java/net/fabricmc/loom/api/LoomGradleExtensionAPI.java @@ -196,4 +196,12 @@ public interface LoomGradleExtensionAPI { */ @ApiStatus.Experimental void disableDeprecatedPomGeneration(MavenPublication publication); + + /** + * Reads the mod version from the fabric.mod.json file located in the main sourcesets resources. + * This is useful if you want to set the gradle version based of the version in the fabric.mod.json file. + * + * @return the version defined in the fabric.mod.json + */ + String getModVersion(); } diff --git a/src/main/java/net/fabricmc/loom/configuration/mods/ModVersionParser.java b/src/main/java/net/fabricmc/loom/configuration/mods/ModVersionParser.java new file mode 100644 index 00000000..09c4fc18 --- /dev/null +++ b/src/main/java/net/fabricmc/loom/configuration/mods/ModVersionParser.java @@ -0,0 +1,76 @@ +/* + * This file is part of fabric-loom, licensed under the MIT License (MIT). + * + * Copyright (c) 2021 FabricMC + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all + * copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ + +package net.fabricmc.loom.configuration.mods; + +import java.io.File; +import java.io.FileReader; +import java.io.IOException; + +import com.google.gson.JsonObject; +import org.gradle.api.Project; +import org.gradle.api.plugins.JavaPluginConvention; + +import net.fabricmc.loom.LoomGradlePlugin; + +public class ModVersionParser { + private final Project project; + + private String version = null; + + public ModVersionParser(Project project) { + this.project = project; + } + + public String getModVersion() { + if (version != null) { + return version; + } + + File json = locateModJsonFile(); + JsonObject jsonObject; + + try (var reader = new FileReader(json)) { + jsonObject = LoomGradlePlugin.GSON.fromJson(reader, JsonObject.class); + } catch (IOException e) { + throw new RuntimeException("Failed to read fabric.mod.json file"); + } + + if (!jsonObject.has("version") || !jsonObject.get("version").isJsonPrimitive()) { + throw new UnsupportedOperationException("Could not find valid version in the fabric.mod.json file"); + } + + version = jsonObject.get("version").getAsString(); + + return version; + } + + private File locateModJsonFile() { + return project.getConvention().getPlugin(JavaPluginConvention.class).getSourceSets() + .getByName("main") + .getResources() + .matching(patternFilterable -> patternFilterable.include("fabric.mod.json")) + .getSingleFile(); + } +} diff --git a/src/main/java/net/fabricmc/loom/extension/LoomGradleExtensionApiImpl.java b/src/main/java/net/fabricmc/loom/extension/LoomGradleExtensionApiImpl.java index 9f0396ad..b1c4b12c 100644 --- a/src/main/java/net/fabricmc/loom/extension/LoomGradleExtensionApiImpl.java +++ b/src/main/java/net/fabricmc/loom/extension/LoomGradleExtensionApiImpl.java @@ -38,6 +38,7 @@ import net.fabricmc.loom.api.LoomGradleExtensionAPI; import net.fabricmc.loom.api.MixinExtensionAPI; import net.fabricmc.loom.api.decompilers.LoomDecompiler; import net.fabricmc.loom.configuration.ide.RunConfigSettings; +import net.fabricmc.loom.configuration.mods.ModVersionParser; import net.fabricmc.loom.configuration.processors.JarProcessor; import net.fabricmc.loom.configuration.providers.mappings.GradleMappingContext; import net.fabricmc.loom.configuration.providers.mappings.LayeredMappingSpec; @@ -59,6 +60,8 @@ public abstract class LoomGradleExtensionApiImpl implements LoomGradleExtensionA protected final Property<String> customManifest; protected final Property<Boolean> setupRemappedVariants; + private final ModVersionParser versionParser; + private NamedDomainObjectContainer<RunConfigSettings> runConfigs; protected LoomGradleExtensionApiImpl(Project project, LoomFiles directories) { @@ -78,6 +81,8 @@ public abstract class LoomGradleExtensionApiImpl implements LoomGradleExtensionA this.setupRemappedVariants = project.getObjects().property(Boolean.class) .convention(true); + this.versionParser = new ModVersionParser(project); + this.deprecationHelper = new DeprecationHelper.ProjectBased(project); } @@ -149,6 +154,11 @@ public abstract class LoomGradleExtensionApiImpl implements LoomGradleExtensionA return setupRemappedVariants; } + @Override + public String getModVersion() { + return versionParser.getModVersion(); + } + protected abstract Project getProject(); protected abstract LoomFiles getFiles(); diff --git a/src/main/java/net/fabricmc/loom/extension/MinecraftGradleExtension.java b/src/main/java/net/fabricmc/loom/extension/MinecraftGradleExtension.java index a209a307..c4ea3d39 100644 --- a/src/main/java/net/fabricmc/loom/extension/MinecraftGradleExtension.java +++ b/src/main/java/net/fabricmc/loom/extension/MinecraftGradleExtension.java @@ -144,4 +144,10 @@ public class MinecraftGradleExtension implements LoomGradleExtensionAPI { reportDeprecation(); parent.disableDeprecatedPomGeneration(publication); } + + @Override + public String getModVersion() { + reportDeprecation(); + throw new UnsupportedOperationException("Use loom extension"); + } } |