From 65d12259d5e5808e6c90689620237d03ccaf9a32 Mon Sep 17 00:00:00 2001 From: Jack Berg Date: Mon, 24 Jul 2023 12:00:13 -0500 Subject: [PATCH] Seperate proto version from nebula.release version --- README.md | 22 ++++++++++++++++++++++ build.gradle.kts | 17 +++++++++-------- 2 files changed, 31 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 933a790..9b7ff8c 100644 --- a/README.md +++ b/README.md @@ -32,6 +32,28 @@ your desired version. implementation("io.opentelemetry.proto:opentelemetry-proto:{{version}}") ``` +## Project setup + +The build downloads proto definitions +from [open-telemetry/opentelemetry-proto](https://github.com/open-telemetry/opentelemetry-proto) and +generates Java bindings: + +```shell +./gradlew build +``` + +By default protos definitions will be downloaded for the latest published tag +of `opentelemetry-proto-java`. For example, if the latest version +is [0.20.0](https://github.com/open-telemetry/opentelemetry-proto-java/tree/v0.20.0), protos will be +downloaded from +the [v0.20.0 release](https://github.com/open-telemetry/opentelemetry-proto/releases/tag/v0.20.0). +This can be overridden for the build or other gradle tasks (e.g. `publishToMavenLocal`) +with `-Prelease.version`: + +```shell +./gradlew build -Prelease.version=1.0.0 +``` + ## Releasing See [RELEASING.md](./RELEASING.md) diff --git a/build.gradle.kts b/build.gradle.kts index 1575db0..34108c1 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -15,6 +15,7 @@ plugins { } release { + defaultVersionStrategy = nebula.plugin.release.git.opinion.Strategies.getSNAPSHOT() } tasks { @@ -25,13 +26,6 @@ tasks { description = "Java Bindings for the OpenTelemetry Protocol (OTLP)" -// Project version is set from -Prelease.version or inferred from the latest tag -if (properties.contains("release.version")) { - version = properties.get("release.version") as String -} else { - version = NearestVersionLocator(TagStrategy()).locate(release.grgit).any.toString() -} - val grpcVersion = "1.56.1" val protobufVersion = "3.23.4" @@ -71,7 +65,14 @@ protobuf { } } -val protoVersion = version +// Proto version is set from -Prelease.version or inferred from the latest tag +var protoVersion = if (properties.contains( + "release.version" + )) { + properties.get("release.version") as String +} else { + NearestVersionLocator(TagStrategy()).locate(release.grgit).any.toString() +} val protoArchive = file("$buildDir/archives/opentelemetry-proto-$protoVersion.zip") tasks {