Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ jobs:
- uses: ./.github/workflows/setup-gradle

- name: Kotlin binary compatibility validator
run: ./gradlew apiCheck
run: ./gradlew checkLegacyAbi

- name: Detekt
run: ./gradlew detektAll
Expand Down
7 changes: 2 additions & 5 deletions .github/workflows/setup-gradle/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,13 @@ description: Setup Gradle and JDK
runs:
using: composite
steps:
- name: Check Gradle wrapper
uses: gradle/wrapper-validation-action@v2

- name: Setup JDK
uses: actions/setup-java@v4
uses: actions/setup-java@v5
with:
distribution: microsoft
java-version: '17'

- name: Setup Gradle
uses: gradle/actions/setup-gradle@v3
uses: gradle/actions/setup-gradle@v5
with:
dependency-graph: generate-and-submit
51 changes: 51 additions & 0 deletions api/semver.klib.api
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
// Klib ABI Dump
// Targets: [iosArm64, iosSimulatorArm64, iosX64, js, linuxArm64, linuxX64, macosArm64, macosX64, mingwX64, tvosArm64, tvosSimulatorArm64, tvosX64, wasmJs, watchosArm32, watchosArm64, watchosDeviceArm64, watchosSimulatorArm64, watchosX64]
// Rendering settings:
// - Signature version: 2
// - Show manifest properties: true
// - Show declarations: true

// Library unique name: <semver>
final class net.swiftzer.semver/SemVer : kotlin/Comparable<net.swiftzer.semver/SemVer> { // net.swiftzer.semver/SemVer|null[0]
constructor <init>(kotlin/Int, kotlin/Int = ..., kotlin/Int = ..., kotlin/String? = ..., kotlin/String? = ...) // net.swiftzer.semver/SemVer.<init>|<init>(kotlin.Int;kotlin.Int;kotlin.Int;kotlin.String?;kotlin.String?){}[0]

final val buildMetadata // net.swiftzer.semver/SemVer.buildMetadata|{}buildMetadata[0]
final fun <get-buildMetadata>(): kotlin/String? // net.swiftzer.semver/SemVer.buildMetadata.<get-buildMetadata>|<get-buildMetadata>(){}[0]
final val major // net.swiftzer.semver/SemVer.major|{}major[0]
final fun <get-major>(): kotlin/Int // net.swiftzer.semver/SemVer.major.<get-major>|<get-major>(){}[0]
final val minor // net.swiftzer.semver/SemVer.minor|{}minor[0]
final fun <get-minor>(): kotlin/Int // net.swiftzer.semver/SemVer.minor.<get-minor>|<get-minor>(){}[0]
final val patch // net.swiftzer.semver/SemVer.patch|{}patch[0]
final fun <get-patch>(): kotlin/Int // net.swiftzer.semver/SemVer.patch.<get-patch>|<get-patch>(){}[0]
final val preRelease // net.swiftzer.semver/SemVer.preRelease|{}preRelease[0]
final fun <get-preRelease>(): kotlin/String? // net.swiftzer.semver/SemVer.preRelease.<get-preRelease>|<get-preRelease>(){}[0]

final fun compareTo(net.swiftzer.semver/SemVer): kotlin/Int // net.swiftzer.semver/SemVer.compareTo|compareTo(net.swiftzer.semver.SemVer){}[0]
final fun component1(): kotlin/Int // net.swiftzer.semver/SemVer.component1|component1(){}[0]
final fun component2(): kotlin/Int // net.swiftzer.semver/SemVer.component2|component2(){}[0]
final fun component3(): kotlin/Int // net.swiftzer.semver/SemVer.component3|component3(){}[0]
final fun component4(): kotlin/String? // net.swiftzer.semver/SemVer.component4|component4(){}[0]
final fun component5(): kotlin/String? // net.swiftzer.semver/SemVer.component5|component5(){}[0]
final fun copy(kotlin/Int = ..., kotlin/Int = ..., kotlin/Int = ..., kotlin/String? = ..., kotlin/String? = ...): net.swiftzer.semver/SemVer // net.swiftzer.semver/SemVer.copy|copy(kotlin.Int;kotlin.Int;kotlin.Int;kotlin.String?;kotlin.String?){}[0]
final fun equals(kotlin/Any?): kotlin/Boolean // net.swiftzer.semver/SemVer.equals|equals(kotlin.Any?){}[0]
final fun hashCode(): kotlin/Int // net.swiftzer.semver/SemVer.hashCode|hashCode(){}[0]
final fun isInitialDevelopmentPhase(): kotlin/Boolean // net.swiftzer.semver/SemVer.isInitialDevelopmentPhase|isInitialDevelopmentPhase(){}[0]
final fun nextMajor(): net.swiftzer.semver/SemVer // net.swiftzer.semver/SemVer.nextMajor|nextMajor(){}[0]
final fun nextMinor(): net.swiftzer.semver/SemVer // net.swiftzer.semver/SemVer.nextMinor|nextMinor(){}[0]
final fun nextPatch(): net.swiftzer.semver/SemVer // net.swiftzer.semver/SemVer.nextPatch|nextPatch(){}[0]
final fun toString(): kotlin/String // net.swiftzer.semver/SemVer.toString|toString(){}[0]

final object Companion { // net.swiftzer.semver/SemVer.Companion|null[0]
final fun parse(kotlin/String): net.swiftzer.semver/SemVer // net.swiftzer.semver/SemVer.Companion.parse|parse(kotlin.String){}[0]
final fun parseOrNull(kotlin/String): net.swiftzer.semver/SemVer? // net.swiftzer.semver/SemVer.Companion.parseOrNull|parseOrNull(kotlin.String){}[0]
final fun serializer(): kotlinx.serialization/KSerializer<net.swiftzer.semver/SemVer> // net.swiftzer.semver/SemVer.Companion.serializer|serializer(){}[0]
}
}

final object net.swiftzer.semver/SemVerSerializer : kotlinx.serialization/KSerializer<net.swiftzer.semver/SemVer> { // net.swiftzer.semver/SemVerSerializer|null[0]
final val descriptor // net.swiftzer.semver/SemVerSerializer.descriptor|{}descriptor[0]
final fun <get-descriptor>(): kotlinx.serialization.descriptors/SerialDescriptor // net.swiftzer.semver/SemVerSerializer.descriptor.<get-descriptor>|<get-descriptor>(){}[0]

final fun deserialize(kotlinx.serialization.encoding/Decoder): net.swiftzer.semver/SemVer // net.swiftzer.semver/SemVerSerializer.deserialize|deserialize(kotlinx.serialization.encoding.Decoder){}[0]
final fun serialize(kotlinx.serialization.encoding/Encoder, net.swiftzer.semver/SemVer) // net.swiftzer.semver/SemVerSerializer.serialize|serialize(kotlinx.serialization.encoding.Encoder;net.swiftzer.semver.SemVer){}[0]
}
16 changes: 13 additions & 3 deletions build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
@file:OptIn(ExperimentalWasmDsl::class)

import com.vanniktech.maven.publish.SonatypeHost
import io.gitlab.arturbosch.detekt.Detekt
import org.jetbrains.kotlin.gradle.ExperimentalWasmDsl
import org.jetbrains.kotlin.gradle.dsl.JvmTarget
import org.jetbrains.kotlin.gradle.dsl.abi.ExperimentalAbiValidation
import java.io.FileInputStream
import java.util.Properties

plugins {
alias(libs.plugins.kotlin.multiplatform)
alias(libs.plugins.kotlinx.binaryCompatibilityValidator)
alias(libs.plugins.kotlinx.serialization)
alias(libs.plugins.dokka)
alias(libs.plugins.kover)
Expand All @@ -26,6 +25,10 @@ if (publishingPropertiesFile.exists()) {

kotlin {
explicitApi()
@OptIn(ExperimentalAbiValidation::class)
abiValidation {
enabled = true
}

jvm {
compilerOptions.jvmTarget = JvmTarget.JVM_1_8
Expand Down Expand Up @@ -100,7 +103,7 @@ dokka {
}

mavenPublishing {
publishToMavenCentral(SonatypeHost.CENTRAL_PORTAL)
publishToMavenCentral()
signAllPublications()
coordinates(
groupId = "net.swiftzer.semver",
Expand Down Expand Up @@ -146,5 +149,12 @@ tasks.register("detektAll") {
dependsOn(tasks.withType<Detekt>())
}

tasks.check {
dependsOn(
// TODO: https://youtrack.jetbrains.com/issue/KT-78525
tasks.checkLegacyAbi,
)
}

fun getProperty(propertyName: String): String? =
providers.environmentVariable(propertyName).orNull ?: publishingProperties.getProperty(propertyName)
2 changes: 0 additions & 2 deletions gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,3 @@ kotlin.native.cacheKind.linuxX64=none
org.gradle.caching=true
org.gradle.jvmargs=-Dfile.encoding=UTF-8
org.gradle.parallel=true
org.jetbrains.dokka.experimental.gradle.pluginMode=V2Enabled
org.jetbrains.dokka.experimental.gradle.pluginMode.noWarn=true
12 changes: 5 additions & 7 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
[versions]
burst = "2.5.0"
burst = "2.10.2"
detekt = "1.23.8"
dokka = "2.0.0"
gradleMavenPublish = "0.33.0"
dokka = "2.1.0"
gradleMavenPublish = "0.35.0"
kotest = "5.9.1"
kotlin = "2.1.21"
kotlinxBinaryCompatibilityValidator = "0.18.1"
kotlinxSerialization = "1.8.1"
kotlin = "2.2.21"
kotlinxSerialization = "1.9.0"
kover = "0.9.1"

[libraries]
Expand All @@ -22,6 +21,5 @@ detekt = { id = "io.gitlab.arturbosch.detekt", version.ref = "detekt" }
dokka = { id = "org.jetbrains.dokka", version.ref = "dokka" }
gradleMavenPublish = { id = "com.vanniktech.maven.publish", version.ref = "gradleMavenPublish" }
kotlin-multiplatform = { id = "org.jetbrains.kotlin.multiplatform", version.ref = "kotlin" }
kotlinx-binaryCompatibilityValidator = { id = "org.jetbrains.kotlinx.binary-compatibility-validator", version.ref = "kotlinxBinaryCompatibilityValidator" }
kotlinx-serialization = { id = "org.jetbrains.kotlin.plugin.serialization", version.ref = "kotlin" }
kover = { id = "org.jetbrains.kotlinx.kover", version.ref = "kover" }
Binary file modified gradle/wrapper/gradle-wrapper.jar
Binary file not shown.
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-9.2.0-bin.zip
networkTimeout=10000
validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME
Expand Down
Loading
Loading