diff --git a/detekt-baseline.xml b/detekt-baseline.xml
index 1a34df6..c80b96c 100644
--- a/detekt-baseline.xml
+++ b/detekt-baseline.xml
@@ -91,7 +91,11 @@
MagicNumber:UUID7.kt$0x80L
MagicNumber:UUID7.kt$12
MagicNumber:UUID7.kt$16
- MatchingDeclarationName:Parcelable.android.kt$Parcelable : Parcelable
+ MatchingDeclarationName:CommonParcelable.apple.kt$CommonParcelable
+ MatchingDeclarationName:CommonParcelable.js.kt$CommonParcelable
+ MatchingDeclarationName:CommonParcelable.jvm.kt$CommonParcelable
+ MatchingDeclarationName:CommonParcelable.linux.kt$CommonParcelable
+ MatchingDeclarationName:CommonParcelable.ming.kt$CommonParcelable
TooManyFunctions:SHA1.kt$SHA1
VariableNaming:UUID7.kt$val rand_a = random.nextBits(12).toLong()
diff --git a/gradle/build-logic/build.gradle.kts b/gradle/build-logic/build.gradle.kts
index b19058b..4202fa6 100644
--- a/gradle/build-logic/build.gradle.kts
+++ b/gradle/build-logic/build.gradle.kts
@@ -5,6 +5,7 @@ plugins {
dependencies {
implementation(libs.plugins.kotlin.jvm.toDep())
implementation(libs.plugins.kotlin.serialization.toDep())
+ implementation(libs.plugins.kotlin.parcelize.toDep())
implementation(libs.plugins.android.toDep())
implementation(libs.plugins.binary.toDep())
implementation(libs.plugins.publish.toDep())
diff --git a/gradle/build-logic/src/main/kotlin/publish.gradle.kts b/gradle/build-logic/src/main/kotlin/publish.gradle.kts
index 866ccab..60aef65 100644
--- a/gradle/build-logic/src/main/kotlin/publish.gradle.kts
+++ b/gradle/build-logic/src/main/kotlin/publish.gradle.kts
@@ -58,4 +58,6 @@ tasks.withType().configureEach {
tasks.withType().configureEach {
isPreserveFileTimestamps = false
isReproducibleFileOrder = true
+ filePermissions {}
+ dirPermissions {}
}
diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml
index 1413167..2b7306a 100644
--- a/gradle/libs.versions.toml
+++ b/gradle/libs.versions.toml
@@ -19,6 +19,7 @@ sqldelight-runtime = { module = "app.cash.sqldelight:runtime", version = "2.0.2"
[plugins]
kotlin-jvm = { id = "org.jetbrains.kotlin.jvm", version.ref = "kotlin" }
kotlin-serialization = { id = "org.jetbrains.kotlin.plugin.serialization", version.ref = "kotlin" }
+kotlin-parcelize = { id = "org.jetbrains.kotlin.plugin.parcelize", version.ref = "kotlin" }
android = { id = "com.android.application", version = "8.5.0" }
binary = { id = "org.jetbrains.kotlinx.binary-compatibility-validator", version = "0.14.0" }
publish = { id = "io.github.gradle-nexus.publish-plugin", version = "2.0.0" }
diff --git a/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api b/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api
index 9786fcb..85dc776 100644
--- a/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api
+++ b/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api
@@ -62,7 +62,7 @@ public final class kotlinx/uuid/Serializer$WrappedCurlyBrackets : kotlinx/uuid/S
public static final field INSTANCE Lkotlinx/uuid/Serializer$WrappedCurlyBrackets;
}
-public final class kotlinx/uuid/UUID : kotlinx/uuid/internal/Parcelable, java/lang/Comparable {
+public final class kotlinx/uuid/UUID : android/os/Parcelable, java/lang/Comparable {
public static final field CREATOR Landroid/os/Parcelable$Creator;
public static final field Companion Lkotlinx/uuid/UUID$Companion;
public fun ()V
@@ -73,6 +73,7 @@ public final class kotlinx/uuid/UUID : kotlinx/uuid/internal/Parcelable, java/la
public synthetic fun (Lkotlinx/uuid/UUID$Version;JIJIILkotlin/jvm/internal/DefaultConstructorMarker;)V
public synthetic fun compareTo (Ljava/lang/Object;)I
public fun compareTo (Lkotlinx/uuid/UUID;)I
+ public final fun describeContents ()I
public fun equals (Ljava/lang/Object;)Z
public final fun getClockSequence ()I
public final fun getNode ()J
@@ -84,6 +85,7 @@ public final class kotlinx/uuid/UUID : kotlinx/uuid/internal/Parcelable, java/la
public final fun isRfcVariant ()Z
public fun toString ()Ljava/lang/String;
public final fun toString (Z)Ljava/lang/String;
+ public final fun writeToParcel (Landroid/os/Parcel;I)V
}
public final class kotlinx/uuid/UUID$Companion {
@@ -92,6 +94,14 @@ public final class kotlinx/uuid/UUID$Companion {
public final fun serializer ()Lkotlinx/serialization/KSerializer;
}
+public final class kotlinx/uuid/UUID$Creator : android/os/Parcelable$Creator {
+ public fun ()V
+ public synthetic fun createFromParcel (Landroid/os/Parcel;)Ljava/lang/Object;
+ public final fun createFromParcel (Landroid/os/Parcel;)Lkotlinx/uuid/UUID;
+ public synthetic fun newArray (I)[Ljava/lang/Object;
+ public final fun newArray (I)[Lkotlinx/uuid/UUID;
+}
+
public final class kotlinx/uuid/UUID$Version : java/lang/Enum {
public static final field DCE_SECURITY Lkotlinx/uuid/UUID$Version;
public static final field NAME_BASED_MD5 Lkotlinx/uuid/UUID$Version;
@@ -118,13 +128,3 @@ public final class kotlinx/uuid/UUIDKt {
public static final fun toUUIDOrNull (Ljava/lang/String;)Lkotlinx/uuid/UUID;
}
-public abstract class kotlinx/uuid/internal/Parcelable : android/os/Parcelable {
- public fun (JJ)V
- public fun describeContents ()I
- public fun writeToParcel (Landroid/os/Parcel;I)V
-}
-
-public final class kotlinx/uuid/internal/Parcelable_androidKt {
- public static final fun getCreator ()Landroid/os/Parcelable$Creator;
-}
-
diff --git a/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api b/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api
index 4a3c1ca..97d07cc 100644
--- a/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api
+++ b/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api
@@ -67,8 +67,7 @@ public final class kotlinx/uuid/Serializer$WrappedCurlyBrackets : kotlinx/uuid/S
public static final field INSTANCE Lkotlinx/uuid/Serializer$WrappedCurlyBrackets;
}
-public final class kotlinx/uuid/UUID : kotlinx/uuid/internal/Parcelable, java/lang/Comparable {
- public static final field CREATOR Lkotlinx/uuid/internal/ParcelableCreator;
+public final class kotlinx/uuid/UUID : java/lang/Comparable, kotlinx/uuid/internal/CommonParcelable {
public static final field Companion Lkotlinx/uuid/UUID$Companion;
public fun ()V
public fun (IJIJI)V
@@ -123,10 +122,6 @@ public final class kotlinx/uuid/UUIDKt {
public static final fun toUUIDOrNull (Ljava/lang/String;)Lkotlinx/uuid/UUID;
}
-public abstract class kotlinx/uuid/internal/Parcelable {
- public fun (JJ)V
-}
-
-public abstract interface class kotlinx/uuid/internal/ParcelableCreator {
+public abstract interface class kotlinx/uuid/internal/CommonParcelable {
}
diff --git a/kotlinx-uuid-core/build.gradle.kts b/kotlinx-uuid-core/build.gradle.kts
index f46163c..d8a74f6 100644
--- a/kotlinx-uuid-core/build.gradle.kts
+++ b/kotlinx-uuid-core/build.gradle.kts
@@ -11,14 +11,15 @@ plugins {
id("dokkaLicensee")
id("kover")
id("com.android.library")
+ kotlin("plugin.parcelize")
}
kotlin {
applyDefaultHierarchyTemplate {
common {
group("linuxDerivat") {
- withAndroidNative()
- withLinux()
+ group("androidNative")
+ group("linux")
}
}
}
@@ -80,4 +81,8 @@ kotlin {
}
}
}
+ compilerOptions.freeCompilerArgs.addAll(
+ "-P",
+ "plugin:org.jetbrains.kotlin.parcelize:additionalAnnotation=kotlinx.uuid.internal.CommonParcelize",
+ )
}
diff --git a/kotlinx-uuid-core/src/androidInstrumentedTest/kotlin/kotlinx/uuid/internal/ParcelableTest.kt b/kotlinx-uuid-core/src/androidInstrumentedTest/kotlin/kotlinx/uuid/internal/ParcelableTest.kt
index 2bd2dde..a36dddc 100644
--- a/kotlinx-uuid-core/src/androidInstrumentedTest/kotlin/kotlinx/uuid/internal/ParcelableTest.kt
+++ b/kotlinx-uuid-core/src/androidInstrumentedTest/kotlin/kotlinx/uuid/internal/ParcelableTest.kt
@@ -2,6 +2,7 @@ package kotlinx.uuid.internal
import android.os.Parcel
import androidx.test.ext.junit.runners.*
+import kotlinx.parcelize.parcelableCreator
import kotlinx.uuid.*
import org.junit.runner.*
import kotlin.test.*
@@ -14,6 +15,6 @@ class ParcelableTest {
val uuid = UUID(SOME_UUID_STRING)
uuid.writeToParcel(parcel, uuid.describeContents())
parcel.setDataPosition(0)
- assertEquals(uuid, UUID.CREATOR.createFromParcel(parcel))
+ assertEquals(uuid, parcelableCreator().createFromParcel(parcel))
}
}
diff --git a/kotlinx-uuid-core/src/androidMain/kotlin/kotlinx/uuid/internal/CommonParcelable.android.kt b/kotlinx-uuid-core/src/androidMain/kotlin/kotlinx/uuid/internal/CommonParcelable.android.kt
new file mode 100644
index 0000000..b0f1a52
--- /dev/null
+++ b/kotlinx-uuid-core/src/androidMain/kotlin/kotlinx/uuid/internal/CommonParcelable.android.kt
@@ -0,0 +1,5 @@
+package kotlinx.uuid.internal
+
+import android.os.*
+
+public actual typealias CommonParcelable = Parcelable
diff --git a/kotlinx-uuid-core/src/androidMain/kotlin/kotlinx/uuid/internal/Parcelable.android.kt b/kotlinx-uuid-core/src/androidMain/kotlin/kotlinx/uuid/internal/Parcelable.android.kt
deleted file mode 100644
index 120194b..0000000
--- a/kotlinx-uuid-core/src/androidMain/kotlin/kotlinx/uuid/internal/Parcelable.android.kt
+++ /dev/null
@@ -1,31 +0,0 @@
-@file:Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-
-package kotlinx.uuid.internal
-
-import android.os.*
-import kotlinx.uuid.*
-
-public actual abstract class Parcelable actual constructor(
- private val timeStampAndVersionRaw: Long,
- private val clockSequenceVariantAndNodeRaw: Long
-) : android.os.Parcelable {
- override fun describeContents(): Int = 0
- override fun writeToParcel(parcel: Parcel, flags: Int) {
- parcel.writeLong(timeStampAndVersionRaw)
- parcel.writeLong(clockSequenceVariantAndNodeRaw)
- }
-}
-
-internal actual typealias ParcelableCreator = android.os.Parcelable.Creator
-
-public actual val creator: ParcelableCreator = object : android.os.Parcelable.Creator {
- override fun createFromParcel(parcel: Parcel): UUID {
- val timeStampAndVersionRaw = parcel.readLong()
- val clockSequenceVariantAndNodeRaw = parcel.readLong()
- return UUID(timeStampAndVersionRaw, clockSequenceVariantAndNodeRaw)
- }
-
- override fun newArray(size: Int): Array {
- return arrayOfNulls(size)
- }
-}
diff --git a/kotlinx-uuid-core/src/appleMain/kotlin/kotlinx/uuid/internal/CommonParcelable.apple.kt b/kotlinx-uuid-core/src/appleMain/kotlin/kotlinx/uuid/internal/CommonParcelable.apple.kt
new file mode 100644
index 0000000..76c06b9
--- /dev/null
+++ b/kotlinx-uuid-core/src/appleMain/kotlin/kotlinx/uuid/internal/CommonParcelable.apple.kt
@@ -0,0 +1,3 @@
+package kotlinx.uuid.internal
+
+public actual interface CommonParcelable
diff --git a/kotlinx-uuid-core/src/appleMain/kotlin/kotlinx/uuid/internal/Parcelable.apple.kt b/kotlinx-uuid-core/src/appleMain/kotlin/kotlinx/uuid/internal/Parcelable.apple.kt
deleted file mode 100644
index b4aef6c..0000000
--- a/kotlinx-uuid-core/src/appleMain/kotlin/kotlinx/uuid/internal/Parcelable.apple.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package kotlinx.uuid.internal
-
-import kotlinx.uuid.*
-
-@Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-public actual abstract class Parcelable actual constructor(
- timeStampAndVersionRaw: Long,
- clockSequenceVariantAndNodeRaw: Long
-)
-
-public actual interface ParcelableCreator
-
-internal actual val creator: ParcelableCreator = object : ParcelableCreator {}
diff --git a/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/UUID.kt b/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/UUID.kt
index 9d04b8f..e6e1652 100644
--- a/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/UUID.kt
+++ b/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/UUID.kt
@@ -12,11 +12,12 @@ import kotlin.jvm.*
* This type represents a UUID as per RFC
* See: https://tools.ietf.org/html/rfc4122
*/
+@CommonParcelize
@Serializable(with = Serializer.Default::class)
public class UUID internal constructor(
internal val timeStampAndVersionRaw: Long,
internal val clockSequenceVariantAndNodeRaw: Long,
-) : Parcelable(timeStampAndVersionRaw, clockSequenceVariantAndNodeRaw), Comparable {
+) : CommonParcelable, Comparable {
private constructor(
helper: UUID
) : this(
@@ -26,7 +27,7 @@ public class UUID internal constructor(
/**
* Creates an instance by the string [uuid] representation.
- * An input string should consist of five hexademical parts
+ * An input string should consist of five hexadecimal parts
* separated with the minus character, and optionally surrounded with curly brackets.
* The space and tab characters are ignored at the end and at the beginning
* and surrounding brackets and minus characters.
@@ -206,9 +207,6 @@ public class UUID internal constructor(
}
private fun versionFor(id: Int): Version? = Version.entries.firstOrNull { it.id == id }
-
- @JvmField
- public val CREATOR: ParcelableCreator = creator
}
}
diff --git a/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/internal/Parcelable.kt b/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/internal/Parcelable.kt
index 0ef753a..15c6dd3 100644
--- a/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/internal/Parcelable.kt
+++ b/kotlinx-uuid-core/src/commonMain/kotlin/kotlinx/uuid/internal/Parcelable.kt
@@ -1,13 +1,6 @@
package kotlinx.uuid.internal
-import kotlinx.uuid.*
+@Target(AnnotationTarget.CLASS)
+internal annotation class CommonParcelize
-@Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-public expect abstract class Parcelable(
- timeStampAndVersionRaw: Long,
- clockSequenceVariantAndNodeRaw: Long
-)
-
-public expect interface ParcelableCreator
-
-internal expect val creator: ParcelableCreator
+public expect interface CommonParcelable
diff --git a/kotlinx-uuid-core/src/jsMain/kotlin/kotlinx/uuid/internal/CommonParcelable.js.kt b/kotlinx-uuid-core/src/jsMain/kotlin/kotlinx/uuid/internal/CommonParcelable.js.kt
new file mode 100644
index 0000000..76c06b9
--- /dev/null
+++ b/kotlinx-uuid-core/src/jsMain/kotlin/kotlinx/uuid/internal/CommonParcelable.js.kt
@@ -0,0 +1,3 @@
+package kotlinx.uuid.internal
+
+public actual interface CommonParcelable
diff --git a/kotlinx-uuid-core/src/jsMain/kotlin/kotlinx/uuid/internal/Parcelable.js.kt b/kotlinx-uuid-core/src/jsMain/kotlin/kotlinx/uuid/internal/Parcelable.js.kt
deleted file mode 100644
index b4aef6c..0000000
--- a/kotlinx-uuid-core/src/jsMain/kotlin/kotlinx/uuid/internal/Parcelable.js.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package kotlinx.uuid.internal
-
-import kotlinx.uuid.*
-
-@Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-public actual abstract class Parcelable actual constructor(
- timeStampAndVersionRaw: Long,
- clockSequenceVariantAndNodeRaw: Long
-)
-
-public actual interface ParcelableCreator
-
-internal actual val creator: ParcelableCreator = object : ParcelableCreator {}
diff --git a/kotlinx-uuid-core/src/jvmMain/kotlin/kotlinx/uuid/internal/CommonParcelable.jvm.kt b/kotlinx-uuid-core/src/jvmMain/kotlin/kotlinx/uuid/internal/CommonParcelable.jvm.kt
new file mode 100644
index 0000000..76c06b9
--- /dev/null
+++ b/kotlinx-uuid-core/src/jvmMain/kotlin/kotlinx/uuid/internal/CommonParcelable.jvm.kt
@@ -0,0 +1,3 @@
+package kotlinx.uuid.internal
+
+public actual interface CommonParcelable
diff --git a/kotlinx-uuid-core/src/jvmMain/kotlin/kotlinx/uuid/internal/Parcelable.jvm.kt b/kotlinx-uuid-core/src/jvmMain/kotlin/kotlinx/uuid/internal/Parcelable.jvm.kt
deleted file mode 100644
index 0f25577..0000000
--- a/kotlinx-uuid-core/src/jvmMain/kotlin/kotlinx/uuid/internal/Parcelable.jvm.kt
+++ /dev/null
@@ -1,15 +0,0 @@
-@file:Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-
-package kotlinx.uuid.internal
-
-import kotlinx.uuid.*
-
-public actual abstract class Parcelable actual constructor(
- timeStampAndVersionRaw: Long,
- clockSequenceVariantAndNodeRaw: Long
-)
-
-public actual interface ParcelableCreator
-
-internal actual val creator: ParcelableCreator = object : ParcelableCreator {
-}
diff --git a/kotlinx-uuid-core/src/linuxDerivatMain/kotlin/kotlinx/uuid/internal/CommonParcelable.linux.kt b/kotlinx-uuid-core/src/linuxDerivatMain/kotlin/kotlinx/uuid/internal/CommonParcelable.linux.kt
new file mode 100644
index 0000000..76c06b9
--- /dev/null
+++ b/kotlinx-uuid-core/src/linuxDerivatMain/kotlin/kotlinx/uuid/internal/CommonParcelable.linux.kt
@@ -0,0 +1,3 @@
+package kotlinx.uuid.internal
+
+public actual interface CommonParcelable
diff --git a/kotlinx-uuid-core/src/linuxDerivatMain/kotlin/kotlinx/uuid/internal/Parcelable.linux.kt b/kotlinx-uuid-core/src/linuxDerivatMain/kotlin/kotlinx/uuid/internal/Parcelable.linux.kt
deleted file mode 100644
index b4aef6c..0000000
--- a/kotlinx-uuid-core/src/linuxDerivatMain/kotlin/kotlinx/uuid/internal/Parcelable.linux.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package kotlinx.uuid.internal
-
-import kotlinx.uuid.*
-
-@Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-public actual abstract class Parcelable actual constructor(
- timeStampAndVersionRaw: Long,
- clockSequenceVariantAndNodeRaw: Long
-)
-
-public actual interface ParcelableCreator
-
-internal actual val creator: ParcelableCreator = object : ParcelableCreator {}
diff --git a/kotlinx-uuid-core/src/mingwX64Main/kotlin/kotlinx/uuid/internal/CommonParcelable.ming.kt b/kotlinx-uuid-core/src/mingwX64Main/kotlin/kotlinx/uuid/internal/CommonParcelable.ming.kt
new file mode 100644
index 0000000..76c06b9
--- /dev/null
+++ b/kotlinx-uuid-core/src/mingwX64Main/kotlin/kotlinx/uuid/internal/CommonParcelable.ming.kt
@@ -0,0 +1,3 @@
+package kotlinx.uuid.internal
+
+public actual interface CommonParcelable
diff --git a/kotlinx-uuid-core/src/mingwX64Main/kotlin/kotlinx/uuid/internal/Parcelable.ming.kt b/kotlinx-uuid-core/src/mingwX64Main/kotlin/kotlinx/uuid/internal/Parcelable.ming.kt
deleted file mode 100644
index b4aef6c..0000000
--- a/kotlinx-uuid-core/src/mingwX64Main/kotlin/kotlinx/uuid/internal/Parcelable.ming.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package kotlinx.uuid.internal
-
-import kotlinx.uuid.*
-
-@Suppress("EXPECT_ACTUAL_CLASSIFIERS_ARE_IN_BETA_WARNING")
-public actual abstract class Parcelable actual constructor(
- timeStampAndVersionRaw: Long,
- clockSequenceVariantAndNodeRaw: Long
-)
-
-public actual interface ParcelableCreator
-
-internal actual val creator: ParcelableCreator = object : ParcelableCreator {}