aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/net/fabricmc/loom/configuration
diff options
context:
space:
mode:
authorshedaniel <daniel@shedaniel.me>2021-05-05 02:21:49 +0800
committershedaniel <daniel@shedaniel.me>2021-05-05 02:21:49 +0800
commitaba834b0402479029aec7f710a92b20176d5b7c5 (patch)
tree02e11a561c2ea02725851d40c6413d9d5b02ff21 /src/main/java/net/fabricmc/loom/configuration
parentf0ec1b61ddfe6ee0bd7b5850fdfaac077bfe42f0 (diff)
parent7ce072c47af8c5b336c36d0f22f6b44b24363f7c (diff)
downloadarchitectury-loom-aba834b0402479029aec7f710a92b20176d5b7c5.tar.gz
architectury-loom-aba834b0402479029aec7f710a92b20176d5b7c5.tar.bz2
architectury-loom-aba834b0402479029aec7f710a92b20176d5b7c5.zip
Merge remote-tracking branch 'FabricMC/future/dev' into dev/future
# Conflicts: # .github/workflows/test-push.yml # src/main/java/net/fabricmc/loom/LoomGradleExtension.java # src/main/java/net/fabricmc/loom/build/ModCompileRemapper.java # src/test/groovy/net/fabricmc/loom/test/util/ProjectTestTrait.groovy
Diffstat (limited to 'src/main/java/net/fabricmc/loom/configuration')
-rw-r--r--src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java12
-rw-r--r--src/main/java/net/fabricmc/loom/configuration/LoomProjectData.java70
2 files changed, 78 insertions, 4 deletions
diff --git a/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java b/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
index a3e7e448..c0d8e4ba 100644
--- a/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
+++ b/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
@@ -112,11 +112,15 @@ public final class CompileConfiguration {
project.getConfigurations().maybeCreate(Constants.Configurations.LOOM_DEVELOPMENT_DEPENDENCIES);
project.getConfigurations().maybeCreate(Constants.Configurations.UNPICK_CLASSPATH);
+ LoomProjectData data = project.getExtensions().getByType(LoomGradleExtension.class).getProjectData();
+
for (RemappedConfigurationEntry entry : Constants.MOD_COMPILE_ENTRIES) {
- Configuration compileModsConfig = project.getConfigurations().maybeCreate(entry.getSourceConfiguration());
- compileModsConfig.setTransitive(true);
- Configuration compileModsMappedConfig = project.getConfigurations().maybeCreate(entry.getRemappedConfiguration());
- compileModsMappedConfig.setTransitive(false); // Don't get transitive deps of already remapped mods
+ data.createLazyConfiguration(entry.getSourceConfiguration())
+ .configure(configuration -> configuration.setTransitive(true));
+
+ // Don't get transitive deps of already remapped mods
+ data.createLazyConfiguration(entry.getRemappedConfiguration())
+ .configure(configuration -> configuration.setTransitive(false));
extendsFrom(entry.getTargetConfiguration(project.getConfigurations()), entry.getRemappedConfiguration(), project);
diff --git a/src/main/java/net/fabricmc/loom/configuration/LoomProjectData.java b/src/main/java/net/fabricmc/loom/configuration/LoomProjectData.java
new file mode 100644
index 00000000..2825ac18
--- /dev/null
+++ b/src/main/java/net/fabricmc/loom/configuration/LoomProjectData.java
@@ -0,0 +1,70 @@
+/*
+ * This file is part of fabric-loom, licensed under the MIT License (MIT).
+ *
+ * Copyright (c) 2016, 2017, 2018 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;
+
+import java.util.HashMap;
+import java.util.Map;
+import java.util.Objects;
+
+import org.gradle.api.NamedDomainObjectProvider;
+import org.gradle.api.Project;
+import org.gradle.api.artifacts.Configuration;
+import org.jetbrains.annotations.ApiStatus;
+
+@ApiStatus.Internal
+/**
+ * This class is stored in the gradle extension, and should not be used outside of loom.
+ * It contains data/info related to the current project
+ */
+public final class LoomProjectData {
+ private final Project project;
+ private final Map<String, NamedDomainObjectProvider<Configuration>> lazyConfigurations = new HashMap<>();
+
+ public LoomProjectData(Project project) {
+ this.project = Objects.requireNonNull(project);
+ }
+
+ public NamedDomainObjectProvider<Configuration> createLazyConfiguration(String name) {
+ NamedDomainObjectProvider<Configuration> provider = project.getConfigurations().register(name);
+
+ if (lazyConfigurations.containsKey(name)) {
+ throw new IllegalStateException("Duplicate configuration name" + name);
+ }
+
+ lazyConfigurations.put(name, provider);
+
+ return provider;
+ }
+
+ public NamedDomainObjectProvider<Configuration> getLazyConfigurationProvider(String name) {
+ NamedDomainObjectProvider<Configuration> provider = lazyConfigurations.get(name);
+
+ if (provider == null) {
+ throw new NullPointerException("Could not find provider with name: " + name);
+ }
+
+ return provider;
+ }
+}