From d7ec017a5b8b07b645331f84b254eb0f28c26b00 Mon Sep 17 00:00:00 2001 From: A248 Date: Thu, 29 Apr 2021 08:10:04 -0400 Subject: [PATCH] Add module descriptor while maintaining Eclipse IDE experience * Fixes #535 * Uses Gradle Eclipse plugin to exclude module-info from compilation in Eclipse. Prevents hordes of issues. --- caffeine/build.gradle | 14 ++++++++++++-- caffeine/src/main/java/module-info.java | 7 +++++++ gradle/codeQuality.gradle | 1 - gradle/dependencies.gradle | 10 +++++++--- guava/build.gradle | 4 ++++ jcache/build.gradle | 4 ++++ simulator/build.gradle | 4 ++++ 7 files changed, 38 insertions(+), 6 deletions(-) create mode 100644 caffeine/src/main/java/module-info.java diff --git a/caffeine/build.gradle b/caffeine/build.gradle index 1500af9690..4ee517147e 100644 --- a/caffeine/build.gradle +++ b/caffeine/build.gradle @@ -23,8 +23,18 @@ idea.module { scopes.PROVIDED.plus += [ configurations.javaPoetCompileClasspath ] } -eclipse.classpath.file.whenMerged { - entries.findAll { it instanceof SourceFolder && it.output == 'bin/codeGen' }*.output = 'bin/main' +eclipse.classpath { + containers 'org.eclipse.buildship.core.gradleclasspathcontainer' + file { + whenMerged { + entries.findAll { + it instanceof SourceFolder && it.output == 'bin/codeGen' + }*.output = 'bin/main' + // Exclude module-info when compiling through Eclipse + def main = entries.find { it instanceof SourceFolder && it.path == 'src/main/java' } + main.excludes.add('module-info.java') + } + } } plugins.withType(EclipsePlugin) { diff --git a/caffeine/src/main/java/module-info.java b/caffeine/src/main/java/module-info.java new file mode 100644 index 0000000000..b90152adc5 --- /dev/null +++ b/caffeine/src/main/java/module-info.java @@ -0,0 +1,7 @@ +module com.github.benmanes.caffeine { + exports com.github.benmanes.caffeine.cache; + exports com.github.benmanes.caffeine.cache.stats; + + requires static transitive com.google.errorprone.annotations; + requires static transitive org.checkerframework.checker.qual; +} diff --git a/gradle/codeQuality.gradle b/gradle/codeQuality.gradle index 19f97dfde9..b756d88942 100644 --- a/gradle/codeQuality.gradle +++ b/gradle/codeQuality.gradle @@ -148,7 +148,6 @@ tasks.withType(JavaCompile).configureEach { annotatedPackages.add('com.github.benmanes.caffeine') } } - modularity.inferModulePath.set(false) checkerFramework.skipCheckerFramework = true } diff --git a/gradle/dependencies.gradle b/gradle/dependencies.gradle index bc9d89216f..11c547302a 100644 --- a/gradle/dependencies.gradle +++ b/gradle/dependencies.gradle @@ -41,7 +41,7 @@ ext { elasticSearch: '7.12.0', expiringMap: '0.5.9', fastfilter: '1.0', - fastutil: '8.5.4', + fastutil: '8.5.2', flipTables: '1.1.0', googleJavaFormat: '1.10.0', guava: '30.1.1-jre', @@ -165,10 +165,14 @@ ext { jcacheTck: "javax.cache:cache-tests:${testVersions.jcacheTck}", jcacheTckTests: "javax.cache:cache-tests:${testVersions.jcacheTck}:tests", jctools: "org.jctools:jctools-core:${testVersions.jctools}", - junit: "junit:junit:${testVersions.junit}", + junit: dependencies.create("junit:junit:${testVersions.junit}") { + exclude group: 'org.hamcrest' + }, mockito: "org.mockito:mockito-core:${testVersions.mockito}", osgiCompile: [ - "org.ops4j.pax.exam:pax-exam-junit4:${testVersions.paxExam}", + dependencies.create("org.ops4j.pax.exam:pax-exam-junit4:${testVersions.paxExam}") { + exclude group: 'org.hamcrest' + }, ], osgiRuntime: [ "org.apache.felix:org.apache.felix.framework:${testVersions.felix}", diff --git a/guava/build.gradle b/guava/build.gradle index b933390b51..69be0fc88d 100644 --- a/guava/build.gradle +++ b/guava/build.gradle @@ -14,6 +14,10 @@ dependencies { testImplementation testLibraries.guavaTestLib } +compileJava { + modularity.inferModulePath = false +} + jar.manifest { attributes 'Bundle-SymbolicName': 'com.github.ben-manes.caffeine.guava' attributes 'Import-Package': [ diff --git a/jcache/build.gradle b/jcache/build.gradle index 710ac5d5ec..15c9c062a0 100644 --- a/jcache/build.gradle +++ b/jcache/build.gradle @@ -30,6 +30,10 @@ dependencies { doc "${libraries.jcache}:javadoc" } +compileJava { + modularity.inferModulePath = false +} + jar.manifest { attributes 'Bundle-SymbolicName': 'com.github.ben-manes.caffeine.jcache' attributes 'Import-Package': [ diff --git a/simulator/build.gradle b/simulator/build.gradle index fc8c357a26..ee7313ce7d 100644 --- a/simulator/build.gradle +++ b/simulator/build.gradle @@ -35,6 +35,10 @@ dependencies { testImplementation testLibraries.testng } +compileJava { + modularity.inferModulePath = false +} + test { useTestNG() }