Use rich version range for openrndr (#293)
This commit is contained in:
2
.github/workflows/build.yml
vendored
2
.github/workflows/build.yml
vendored
@@ -45,7 +45,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Build OPENRNDR
|
- name: Build OPENRNDR
|
||||||
working-directory: ./openrndr
|
working-directory: ./openrndr
|
||||||
run: ./gradlew publishToMavenLocal -Prelease.version=0.5.1-SNAPSHOT
|
run: ./gradlew publishToMavenLocal snapshot
|
||||||
|
|
||||||
- name: Build ORX
|
- name: Build ORX
|
||||||
run: ./gradlew build
|
run: ./gradlew build
|
||||||
|
|||||||
2
.github/workflows/generate-screenshots.yml
vendored
2
.github/workflows/generate-screenshots.yml
vendored
@@ -41,7 +41,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Build OPENRNDR
|
- name: Build OPENRNDR
|
||||||
working-directory: ./openrndr
|
working-directory: ./openrndr
|
||||||
run: ./gradlew publishToMavenLocal -Prelease.version=0.5.1-SNAPSHOT
|
run: ./gradlew publishToMavenLocal snapshot
|
||||||
|
|
||||||
- name: Build ORX
|
- name: Build ORX
|
||||||
run: ./gradlew build
|
run: ./gradlew build
|
||||||
|
|||||||
@@ -7,26 +7,19 @@ jobs:
|
|||||||
release_candidate_to_maven_central:
|
release_candidate_to_maven_central:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Get OPENRNDR release tag
|
|
||||||
run: echo "OPENRNDR_VERSION=$(git ls-remote --refs --tags https://github.com/openrndr/openrndr | cut --delimiter='/' --fields=3 | sort --version-sort | tail --lines=1)" >> $GITHUB_ENV
|
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Get the version
|
|
||||||
id: get_version
|
|
||||||
run: echo ::set-output name=VERSION::${GITHUB_REF/refs\/tags\/v/}
|
|
||||||
- uses: actions/setup-java@v3
|
- uses: actions/setup-java@v3
|
||||||
with:
|
with:
|
||||||
distribution: temurin
|
distribution: temurin
|
||||||
java-version: 17
|
java-version: 17
|
||||||
- name: Build ORX
|
- name: Build ORX
|
||||||
env:
|
run: ./gradlew -Prelease.useLastTag=true build
|
||||||
OPENRNDR_VERSION: ${{ env.OPENRNDR_VERSION }}
|
|
||||||
run: ./gradlew -POPENRNDR.version=${{ env.OPENRNDR_VERSION }} -Prelease.useLastTag=true build
|
|
||||||
- name: Decode
|
- name: Decode
|
||||||
run: |
|
run: |
|
||||||
echo "${{secrets.SIGNING_SECRET_KEY_RING_FILE}}" > ~/.gradle/secring.gpg.b64
|
echo "${{secrets.SIGNING_SECRET_KEY_RING_FILE}}" > ~/.gradle/secring.gpg.b64
|
||||||
base64 -d ~/.gradle/secring.gpg.b64 > ~/.gradle/secring.gpg
|
base64 -d ~/.gradle/secring.gpg.b64 > ~/.gradle/secring.gpg
|
||||||
- name: Publish
|
- name: Publish
|
||||||
run: ./gradlew publishToSonatype -POPENRNDR.version=${{env.OPENRNDR_VERSION}} -Prelease.useLastTag=true -Psigning.keyId=${{secrets.SIGNING_KEY_ID}} -Psigning.password=openrndr -Psigning.secretKeyRingFile=$(echo ~/.gradle/secring.gpg)
|
run: ./gradlew publishToSonatype -Prelease.useLastTag=true -Psigning.keyId=${{secrets.SIGNING_KEY_ID}} -Psigning.password=openrndr -Psigning.secretKeyRingFile=$(echo ~/.gradle/secring.gpg)
|
||||||
env:
|
env:
|
||||||
OSSRH_USERNAME: ${{secrets.OSSRH_USERNAME}}
|
OSSRH_USERNAME: ${{secrets.OSSRH_USERNAME}}
|
||||||
OSSRH_PASSWORD: ${{secrets.OSSRH_PASSWORD}}
|
OSSRH_PASSWORD: ${{secrets.OSSRH_PASSWORD}}
|
||||||
11
.github/workflows/release-to-maven-central.yml
vendored
11
.github/workflows/release-to-maven-central.yml
vendored
@@ -9,26 +9,19 @@ jobs:
|
|||||||
release_to_maven_central:
|
release_to_maven_central:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Get OPENRNDR release tag
|
|
||||||
run: echo "OPENRNDR_VERSION=$(git -c 'versionsort.suffix=-' ls-remote --tags --sort='v:refname' https://github.com/openrndr/openrndr | cut --delimiter='/' --fields=3 | tail --lines=1)" >> $GITHUB_ENV
|
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Get the version
|
|
||||||
id: get_version
|
|
||||||
run: echo ::set-output name=VERSION::${GITHUB_REF/refs\/tags\/v/}
|
|
||||||
- uses: actions/setup-java@v3
|
- uses: actions/setup-java@v3
|
||||||
with:
|
with:
|
||||||
distribution: temurin
|
distribution: temurin
|
||||||
java-version: 17
|
java-version: 17
|
||||||
- name: Build ORX
|
- name: Build ORX
|
||||||
env:
|
run: ./gradlew -Prelease.useLastTag=true build
|
||||||
OPENRNDR_VERSION: ${{ env.OPENRNDR_VERSION }}
|
|
||||||
run: ./gradlew -POPENRNDR.version=${{ env.OPENRNDR_VERSION }} -Prelease.useLastTag=true build
|
|
||||||
- name: Decode
|
- name: Decode
|
||||||
run: |
|
run: |
|
||||||
echo "${{secrets.SIGNING_SECRET_KEY_RING_FILE}}" > ~/.gradle/secring.gpg.b64
|
echo "${{secrets.SIGNING_SECRET_KEY_RING_FILE}}" > ~/.gradle/secring.gpg.b64
|
||||||
base64 -d ~/.gradle/secring.gpg.b64 > ~/.gradle/secring.gpg
|
base64 -d ~/.gradle/secring.gpg.b64 > ~/.gradle/secring.gpg
|
||||||
- name: Publish
|
- name: Publish
|
||||||
run: ./gradlew publishToSonatype -POPENRNDR.version=${{env.OPENRNDR_VERSION}} -Prelease.useLastTag=true -Psigning.keyId=${{secrets.SIGNING_KEY_ID}} -Psigning.password=openrndr -Psigning.secretKeyRingFile=$(echo ~/.gradle/secring.gpg)
|
run: ./gradlew publishToSonatype -Prelease.useLastTag=true -Psigning.keyId=${{secrets.SIGNING_KEY_ID}} -Psigning.password=openrndr -Psigning.secretKeyRingFile=$(echo ~/.gradle/secring.gpg)
|
||||||
env:
|
env:
|
||||||
OSSRH_USERNAME: ${{secrets.OSSRH_USERNAME}}
|
OSSRH_USERNAME: ${{secrets.OSSRH_USERNAME}}
|
||||||
OSSRH_PASSWORD: ${{secrets.OSSRH_PASSWORD}}
|
OSSRH_PASSWORD: ${{secrets.OSSRH_PASSWORD}}
|
||||||
35
README.md
35
README.md
@@ -1,8 +1,7 @@
|
|||||||
# ORX (OPENRNDR EXTRA) 0.4
|
# ORX (OPENRNDR EXTRA)
|
||||||
|
|
||||||
Note that this is a yet unreleased version of ORX. The prior released version of ORX can be found in the [ORX 0.3 branch](https://github.com/openrndr/orx/tree/orx-0.3).
|
A growing library of assorted data structures, algorithms and utilities to
|
||||||
|
complement [OPENRNDR](https://github.com/openrndr/openrndr).
|
||||||
A growing library of assorted data structures, algorithms and utilities.
|
|
||||||
|
|
||||||
<!-- __orxListBegin__ -->
|
<!-- __orxListBegin__ -->
|
||||||
|
|
||||||
@@ -70,10 +69,30 @@ A growing library of assorted data structures, algorithms and utilities.
|
|||||||
|
|
||||||
# Developer notes
|
# Developer notes
|
||||||
|
|
||||||
## Create and use local builds of the library
|
## Publish and use local builds of the library in your applications
|
||||||
|
|
||||||
First build and publish OPENRNDR 0.4 SNAPSHOT (using `-Prelease.version=0.5.1-SNAPSHOT`) from the `openrndr-0.4` branch.
|
First, build and publish [OPENRNDR](https://github.com/openrndr/openrndr) to the local maven repository:
|
||||||
|
|
||||||
run `./gradlew publishToMavenLocal -Prelease.version=0.5.1-SNAPSHOT` (or import in IntelliJ IDEA and edit the run configuration)
|
Run (or import in IntelliJ IDEA and edit the run configuration).
|
||||||
|
```sh
|
||||||
|
# In openrndr repository
|
||||||
|
./gradlew publishToMavenLocal snapshot
|
||||||
|
```
|
||||||
|
|
||||||
In an [`openrndr-template`](https://youtu.be/saAzoREfa90?t=787) based project set `orxUseSnapshot = true` in order to use the snapshot build.
|
This command will build and publish a snapshot of the next version of the library. For example, if the current latest
|
||||||
|
release is 0.4.2, then it will create a release named "0.4.3-SNAPSHOT" and publish it to your local maven repository.
|
||||||
|
The exact version will be shown in the console output during the build process.
|
||||||
|
|
||||||
|
Now you can run the same command again but for this repository.
|
||||||
|
|
||||||
|
```sh
|
||||||
|
# In orx repository
|
||||||
|
./gradlew publishToMavenLocal snapshot
|
||||||
|
```
|
||||||
|
|
||||||
|
It will automatically use the locally published snapshot of OPENRNDR for building ORX and will publish ORX to your local
|
||||||
|
maven repository with the same logic as before.
|
||||||
|
|
||||||
|
Once that's done, you can use the local build of ORX in
|
||||||
|
your [openrndr-template](https://github.com/openrndr/openrndr-template) by specifying the version you published. In this
|
||||||
|
case, it would be "0.4.3-SNAPSHOT".
|
||||||
@@ -206,7 +206,7 @@ configure(allprojects.findAll { !doNotPublish.contains(it.name) && !multiplatfor
|
|||||||
from components.java
|
from components.java
|
||||||
versionMapping {
|
versionMapping {
|
||||||
allVariants {
|
allVariants {
|
||||||
fromResolutionOf("default")
|
fromResolutionResult()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
groupId = "org.openrndr.extra"
|
groupId = "org.openrndr.extra"
|
||||||
|
|||||||
@@ -9,16 +9,6 @@ repositories {
|
|||||||
mavenLocal()
|
mavenLocal()
|
||||||
}
|
}
|
||||||
|
|
||||||
val openrndrVersion: String =
|
|
||||||
(extra.properties["OPENRNDR.version"] as String? ?: System.getenv("OPENRNDR_VERSION"))?.removePrefix("v")
|
|
||||||
?: "0.5.1-SNAPSHOT"
|
|
||||||
|
|
||||||
configurations.all {
|
|
||||||
resolutionStrategy.eachDependency {
|
|
||||||
if (requested.group == "org.openrndr") useVersion(openrndrVersion)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation(libs.kotlin.gradle.plugin)
|
implementation(libs.kotlin.gradle.plugin)
|
||||||
implementation(libs.dokka.gradle.plugin)
|
implementation(libs.dokka.gradle.plugin)
|
||||||
|
|||||||
@@ -2,16 +2,6 @@ package org.openrndr.extra.convention
|
|||||||
|
|
||||||
addHostMachineAttributesToRuntimeConfigurations()
|
addHostMachineAttributesToRuntimeConfigurations()
|
||||||
|
|
||||||
val openrndrVersion: String =
|
|
||||||
(extra.properties["OPENRNDR.version"] as String? ?: System.getenv("OPENRNDR_VERSION"))?.removePrefix("v")
|
|
||||||
?: "0.5.1-SNAPSHOT"
|
|
||||||
|
|
||||||
configurations.all {
|
|
||||||
resolutionStrategy.eachDependency {
|
|
||||||
if (requested.group == "org.openrndr") useVersion(openrndrVersion)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
components {
|
components {
|
||||||
all<LwjglRule>()
|
all<LwjglRule>()
|
||||||
|
|||||||
@@ -3,7 +3,6 @@ package org.openrndr.extra.convention
|
|||||||
import org.gradle.accessors.dm.LibrariesForLibs
|
import org.gradle.accessors.dm.LibrariesForLibs
|
||||||
import org.gradle.api.tasks.testing.logging.TestExceptionFormat
|
import org.gradle.api.tasks.testing.logging.TestExceptionFormat
|
||||||
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
|
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
|
||||||
import java.net.URI
|
|
||||||
|
|
||||||
val libs = the<LibrariesForLibs>()
|
val libs = the<LibrariesForLibs>()
|
||||||
|
|
||||||
@@ -22,10 +21,10 @@ repositories {
|
|||||||
|
|
||||||
group = "org.openrndr.extra"
|
group = "org.openrndr.extra"
|
||||||
|
|
||||||
val main by sourceSets.getting
|
val main: SourceSet by sourceSets.getting
|
||||||
|
|
||||||
@Suppress("UNUSED_VARIABLE")
|
@Suppress("UNUSED_VARIABLE")
|
||||||
val demo by sourceSets.creating
|
val demo: SourceSet by sourceSets.creating
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation(libs.kotlin.stdlib)
|
implementation(libs.kotlin.stdlib)
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import CollectScreenshotsTask
|
|||||||
import org.gradle.accessors.dm.LibrariesForLibs
|
import org.gradle.accessors.dm.LibrariesForLibs
|
||||||
import org.gradle.api.tasks.testing.logging.TestExceptionFormat
|
import org.gradle.api.tasks.testing.logging.TestExceptionFormat
|
||||||
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
|
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
|
||||||
import java.net.URI
|
|
||||||
|
|
||||||
val libs = the<LibrariesForLibs>()
|
val libs = the<LibrariesForLibs>()
|
||||||
|
|
||||||
@@ -31,7 +30,8 @@ kotlin {
|
|||||||
jvm {
|
jvm {
|
||||||
jvmToolchain(libs.versions.jvmTarget.get().toInt())
|
jvmToolchain(libs.versions.jvmTarget.get().toInt())
|
||||||
compilations {
|
compilations {
|
||||||
val main by getting
|
val main by getting
|
||||||
|
|
||||||
@Suppress("UNUSED_VARIABLE")
|
@Suppress("UNUSED_VARIABLE")
|
||||||
val demo by creating {
|
val demo by creating {
|
||||||
associateWith(main)
|
associateWith(main)
|
||||||
@@ -39,7 +39,7 @@ kotlin {
|
|||||||
inputDir.set(output.classesDirs.singleFile)
|
inputDir.set(output.classesDirs.singleFile)
|
||||||
runtimeDependencies.set(runtimeDependencyFiles)
|
runtimeDependencies.set(runtimeDependencyFiles)
|
||||||
outputDir.set(project.file(project.projectDir.toString() + "/images"))
|
outputDir.set(project.file(project.projectDir.toString() + "/images"))
|
||||||
dependsOn(compileKotlinTask)
|
dependsOn(compileTaskProvider)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ kotlinApi = "1.8"
|
|||||||
kotlinLanguage = "1.8"
|
kotlinLanguage = "1.8"
|
||||||
kotlin = "1.8.10"
|
kotlin = "1.8.10"
|
||||||
jvmTarget = "11"
|
jvmTarget = "11"
|
||||||
openrndr = "0.0.0"
|
openrndr = { require = "[0.4.2, 1.0.0)" }
|
||||||
kotlinxCoroutines = "1.6.4"
|
kotlinxCoroutines = "1.6.4"
|
||||||
kotlinLogging = "3.0.0"
|
kotlinLogging = "3.0.0"
|
||||||
kotlinxSerialization = "1.5.0-RC"
|
kotlinxSerialization = "1.5.0-RC"
|
||||||
|
|||||||
Reference in New Issue
Block a user