aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
diff options
context:
space:
mode:
authormodmuss50 <modmuss50@gmail.com>2021-05-04 20:06:24 +0100
committermodmuss50 <modmuss50@gmail.com>2021-05-04 20:06:24 +0100
commit927180e36b8ec957c0271fc122da9c92ebc04304 (patch)
treedabda677e60a3a1938943dc4b29c6dbebbbc8a42 /src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
parentf4f660dce55f153d41fc0435e72dcdc0cffb8549 (diff)
downloadarchitectury-loom-927180e36b8ec957c0271fc122da9c92ebc04304.tar.gz
architectury-loom-927180e36b8ec957c0271fc122da9c92ebc04304.tar.bz2
architectury-loom-927180e36b8ec957c0271fc122da9c92ebc04304.zip
Make all loom added configurations lazy
Diffstat (limited to 'src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java')
-rw-r--r--src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java46
1 files changed, 19 insertions, 27 deletions
diff --git a/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java b/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
index 9199bab4..ce6dea44 100644
--- a/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
+++ b/src/main/java/net/fabricmc/loom/configuration/CompileConfiguration.java
@@ -25,7 +25,7 @@
package net.fabricmc.loom.configuration;
import org.gradle.api.Project;
-import org.gradle.api.artifacts.Configuration;
+import org.gradle.api.artifacts.ConfigurationContainer;
import org.gradle.api.plugins.JavaPlugin;
import org.gradle.api.plugins.JavaPluginConvention;
import org.gradle.api.tasks.SourceSet;
@@ -47,32 +47,24 @@ public final class CompileConfiguration {
}
public static void setupConfigurations(Project project) {
- Configuration modCompileClasspathConfig = project.getConfigurations().maybeCreate(Constants.Configurations.MOD_COMPILE_CLASSPATH);
- modCompileClasspathConfig.setTransitive(true);
- Configuration modCompileClasspathMappedConfig = project.getConfigurations().maybeCreate(Constants.Configurations.MOD_COMPILE_CLASSPATH_MAPPED);
- modCompileClasspathMappedConfig.setTransitive(false);
-
- Configuration minecraftNamedConfig = project.getConfigurations().maybeCreate(Constants.Configurations.MINECRAFT_NAMED);
- minecraftNamedConfig.setTransitive(false); // The launchers do not recurse dependencies
- Configuration minecraftDependenciesConfig = project.getConfigurations().maybeCreate(Constants.Configurations.MINECRAFT_DEPENDENCIES);
- minecraftDependenciesConfig.setTransitive(false);
- Configuration loaderDependenciesConfig = project.getConfigurations().maybeCreate(Constants.Configurations.LOADER_DEPENDENCIES);
- loaderDependenciesConfig.setTransitive(false);
- Configuration minecraftConfig = project.getConfigurations().maybeCreate(Constants.Configurations.MINECRAFT);
- minecraftConfig.setTransitive(false);
-
- Configuration includeConfig = project.getConfigurations().maybeCreate(Constants.Configurations.INCLUDE);
- includeConfig.setTransitive(false); // Dont get transitive deps
-
- project.getConfigurations().maybeCreate(Constants.Configurations.MAPPING_CONSTANTS);
- extendsFrom(JavaPlugin.COMPILE_ONLY_CONFIGURATION_NAME, Constants.Configurations.MAPPING_CONSTANTS, project);
+ final ConfigurationContainer configurations = project.getConfigurations();
+ LoomProjectData data = project.getExtensions().getByType(LoomGradleExtension.class).getProjectData();
- project.getConfigurations().maybeCreate(Constants.Configurations.MAPPINGS);
- project.getConfigurations().maybeCreate(Constants.Configurations.MAPPINGS_FINAL);
- project.getConfigurations().maybeCreate(Constants.Configurations.LOOM_DEVELOPMENT_DEPENDENCIES);
- project.getConfigurations().maybeCreate(Constants.Configurations.UNPICK_CLASSPATH);
+ data.createLazyConfiguration(Constants.Configurations.MOD_COMPILE_CLASSPATH).configure(configuration -> configuration.setTransitive(true));
+ data.createLazyConfiguration(Constants.Configurations.MOD_COMPILE_CLASSPATH_MAPPED).configure(configuration -> configuration.setTransitive(false));
+ data.createLazyConfiguration(Constants.Configurations.MINECRAFT_NAMED).configure(configuration -> configuration.setTransitive(false)); // The launchers do not recurse dependencies
+ data.createLazyConfiguration(Constants.Configurations.MINECRAFT_DEPENDENCIES).configure(configuration -> configuration.setTransitive(false));
+ data.createLazyConfiguration(Constants.Configurations.LOADER_DEPENDENCIES).configure(configuration -> configuration.setTransitive(false));
+ data.createLazyConfiguration(Constants.Configurations.MINECRAFT).configure(configuration -> configuration.setTransitive(false));
+ data.createLazyConfiguration(Constants.Configurations.INCLUDE).configure(configuration -> configuration.setTransitive(false)); // Dont get transitive deps
+ data.createLazyConfiguration(Constants.Configurations.MAPPING_CONSTANTS);
- LoomProjectData data = project.getExtensions().getByType(LoomGradleExtension.class).getProjectData();
+ extendsFrom(JavaPlugin.COMPILE_ONLY_CONFIGURATION_NAME, Constants.Configurations.MAPPING_CONSTANTS, project);
+
+ data.createLazyConfiguration(Constants.Configurations.MAPPINGS);
+ data.createLazyConfiguration(Constants.Configurations.MAPPINGS_FINAL);
+ data.createLazyConfiguration(Constants.Configurations.LOOM_DEVELOPMENT_DEPENDENCIES);
+ data.createLazyConfiguration(Constants.Configurations.UNPICK_CLASSPATH);
for (RemappedConfigurationEntry entry : Constants.MOD_COMPILE_ENTRIES) {
data.createLazyConfiguration(entry.getSourceConfiguration())
@@ -82,7 +74,7 @@ public final class CompileConfiguration {
data.createLazyConfiguration(entry.getRemappedConfiguration())
.configure(configuration -> configuration.setTransitive(false));
- extendsFrom(entry.getTargetConfiguration(project.getConfigurations()), entry.getRemappedConfiguration(), project);
+ extendsFrom(entry.getTargetConfiguration(configurations), entry.getRemappedConfiguration(), project);
if (entry.isOnModCompileClasspath()) {
extendsFrom(Constants.Configurations.MOD_COMPILE_CLASSPATH, entry.getSourceConfiguration(), project);
@@ -166,6 +158,6 @@ public final class CompileConfiguration {
}
private static void extendsFrom(String a, String b, Project project) {
- project.getConfigurations().getByName(a).extendsFrom(project.getConfigurations().getByName(b));
+ project.getConfigurations().getByName(a, configuration -> configuration.extendsFrom(project.getConfigurations().getByName(b)));
}
}