From 714f31da2bce0fe9c949e796468bcb749541a092 Mon Sep 17 00:00:00 2001 From: Luke Bemish Date: Mon, 12 Aug 2024 04:22:06 -0500 Subject: [PATCH] Make new utilities not completely bypass capabilities (#234) --- .../sourcesets/SourceSetDependencyExtensionImpl.java | 12 +++--------- .../SourceSetInheritanceExtensionImpl.java | 12 ++++-------- .../neoforged/gradle/userdev/SourceSetTests.groovy | 1 - 3 files changed, 7 insertions(+), 18 deletions(-) diff --git a/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetDependencyExtensionImpl.java b/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetDependencyExtensionImpl.java index 10156e69..56e40cbd 100644 --- a/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetDependencyExtensionImpl.java +++ b/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetDependencyExtensionImpl.java @@ -43,15 +43,9 @@ public void on(SourceSet sourceSet) { final SourceSetInheritanceExtension sourceSetInheritanceExtension = target.getExtensions().getByType(SourceSetInheritanceExtension.class); sourceSetInheritanceExtension.from(sourceSet); - target.setCompileClasspath( - target.getCompileClasspath().plus( - sourceSet.getOutput() - ) - ); - target.setRuntimeClasspath( - target.getRuntimeClasspath().plus( - sourceSet.getOutput() - ) + project.getDependencies().add( + target.getImplementationConfigurationName(), + sourceSet.getOutput() ); } } diff --git a/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetInheritanceExtensionImpl.java b/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetInheritanceExtensionImpl.java index b4ce6bcd..39ed390a 100644 --- a/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetInheritanceExtensionImpl.java +++ b/common/src/main/java/net/neoforged/gradle/common/extensions/sourcesets/SourceSetInheritanceExtensionImpl.java @@ -39,15 +39,11 @@ public void from(SourceSet sourceSet) { ); } - target.setCompileClasspath( - target.getCompileClasspath().plus( - sourceSet.getCompileClasspath() - ) + project.getConfigurations().getByName(target.getCompileClasspathConfigurationName()).extendsFrom( + project.getConfigurations().getByName(sourceSet.getCompileClasspathConfigurationName()) ); - target.setRuntimeClasspath( - target.getRuntimeClasspath().plus( - sourceSet.getRuntimeClasspath() - ) + project.getConfigurations().getByName(target.getRuntimeClasspathConfigurationName()).extendsFrom( + project.getConfigurations().getByName(sourceSet.getRuntimeClasspathConfigurationName()) ); } } diff --git a/userdev/src/functionalTest/groovy/net/neoforged/gradle/userdev/SourceSetTests.groovy b/userdev/src/functionalTest/groovy/net/neoforged/gradle/userdev/SourceSetTests.groovy index 60fdcf01..c0365f59 100644 --- a/userdev/src/functionalTest/groovy/net/neoforged/gradle/userdev/SourceSetTests.groovy +++ b/userdev/src/functionalTest/groovy/net/neoforged/gradle/userdev/SourceSetTests.groovy @@ -102,7 +102,6 @@ class SourceSetTests extends BuilderBasedTestSpecification { then: run.getOutput().contains("com.google.code.gson/gson/2.11.0") || run.getOutput().contains("com.google.code.gson\\gson\\2.11.0") - run.getOutput().contains("inheriting_sourcesets_runtime/build/classes/java/main") || run.getOutput().contains("inheriting_sourcesets_runtime\\build\\classes\\java\\main") } def "depending on a sourceset adds the compile dependencies"() {