From ff2f9cacd1d8ee24bf41e96840c6959310847fa1 Mon Sep 17 00:00:00 2001 From: Roy Teeuwen Date: Fri, 23 Aug 2024 16:03:12 +0200 Subject: [PATCH 1/3] solves #768: Add OSGi support by exporting all java packages except internal packages --- buildSrc/build.gradle.kts | 1 + buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts | 6 ++++++ 2 files changed, 7 insertions(+) diff --git a/buildSrc/build.gradle.kts b/buildSrc/build.gradle.kts index d85c65767de..e2066365c5d 100644 --- a/buildSrc/build.gradle.kts +++ b/buildSrc/build.gradle.kts @@ -50,6 +50,7 @@ repositories { } dependencies { + implementation("biz.aQute.bnd:biz.aQute.bnd.gradle:7.0.0") implementation(enforcedPlatform("com.squareup.wire:wire-bom:5.0.0")) implementation("com.google.auto.value:auto-value-annotations:1.11.0") // When updating, update above in plugins too diff --git a/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts b/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts index f651f5c3021..8db53d9e8f1 100644 --- a/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts +++ b/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts @@ -8,6 +8,7 @@ plugins { eclipse idea + id("biz.aQute.bnd.builder") id("otel.errorprone-conventions") id("otel.jacoco-conventions") id("otel.spotless-conventions") @@ -155,10 +156,15 @@ tasks { "Built-JDK" to System.getProperty("java.version"), "Implementation-Title" to project.name, "Implementation-Version" to project.version, + // BND plugin to export the packages as OSGi bundle + "-exportcontents" to "!io.opentelemetry.**.internal,io.opentelemetry.*," ) } + } + + afterEvaluate { withType().configureEach { with(options as StandardJavadocDocletOptions) { From 0b080b2ef3d0c4f47644bb4d43bd8e87d06ccc59 Mon Sep 17 00:00:00 2001 From: Barry d'Hoine Date: Fri, 23 Aug 2024 22:48:21 +0200 Subject: [PATCH 2/3] Remove unneeded newlines --- buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts | 3 --- 1 file changed, 3 deletions(-) diff --git a/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts b/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts index 8db53d9e8f1..5dca3511e79 100644 --- a/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts +++ b/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts @@ -160,11 +160,8 @@ tasks { "-exportcontents" to "!io.opentelemetry.**.internal,io.opentelemetry.*," ) } - } - - afterEvaluate { withType().configureEach { with(options as StandardJavadocDocletOptions) { From 769923c383169737605b221b5d7ba1d74dd2ec29 Mon Sep 17 00:00:00 2001 From: Barry d'Hoine Date: Fri, 23 Aug 2024 23:37:06 +0200 Subject: [PATCH 3/3] use module name as package scope to export content to bundle --- buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts b/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts index 5dca3511e79..652c0eb72e8 100644 --- a/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts +++ b/buildSrc/src/main/kotlin/otel.java-conventions.gradle.kts @@ -157,7 +157,7 @@ tasks { "Implementation-Title" to project.name, "Implementation-Version" to project.version, // BND plugin to export the packages as OSGi bundle - "-exportcontents" to "!io.opentelemetry.**.internal,io.opentelemetry.*," + "-exportcontents" to "!${otelJava.moduleName.get()}.**.internal,${otelJava.moduleName.get()}.*" ) } }