Use kotlin 1.9
This commit is contained in:
		
							parent
							
								
									e94e41b896
								
							
						
					
					
						commit
						0c549c8bb7
					
				
							
								
								
									
										4
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @ -86,7 +86,7 @@ jobs: | |||||||
|       - name: Check Linux |       - name: Check Linux | ||||||
|         if: matrix.os == 'ubuntu-latest' |         if: matrix.os == 'ubuntu-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: ./gradlew linuxTest |         run: ./gradlew linuxX64Test | ||||||
|       - name: Check iOS |       - name: Check iOS | ||||||
|         if: matrix.os == 'macOS-latest' |         if: matrix.os == 'macOS-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
| @ -103,7 +103,7 @@ jobs: | |||||||
|       - name: Publish Linux |       - name: Publish Linux | ||||||
|         if: matrix.os == 'ubuntu-latest' |         if: matrix.os == 'ubuntu-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: ./gradlew publishLinuxPublicationToMavenLocal :jni:jvm:linux:publishJvmPublicationToMavenLocal |         run: ./gradlew publishLinuxX64PublicationToMavenLocal :jni:jvm:linux:publishJvmPublicationToMavenLocal | ||||||
|       - name: Publish Windows |       - name: Publish Windows | ||||||
|         if: matrix.os == 'windows-latest' |         if: matrix.os == 'windows-latest' | ||||||
|         shell: msys2 {0} |         shell: msys2 {0} | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								.github/workflows/snapshot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/snapshot.yml
									
									
									
									
										vendored
									
									
								
							| @ -95,7 +95,7 @@ jobs: | |||||||
|       - name: Check Linux |       - name: Check Linux | ||||||
|         if: matrix.os == 'ubuntu-latest' |         if: matrix.os == 'ubuntu-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: ./gradlew linuxTest |         run: ./gradlew linuxX64Test | ||||||
|       - name: Check iOS |       - name: Check iOS | ||||||
|         if: matrix.os == 'macOS-latest' |         if: matrix.os == 'macOS-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
| @ -112,7 +112,7 @@ jobs: | |||||||
|       - name: Publish Linux |       - name: Publish Linux | ||||||
|         if: matrix.os == 'ubuntu-latest' |         if: matrix.os == 'ubuntu-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: ./gradlew publishLinuxPublicationToMavenLocal :jni:jvm:linux:publishJvmPublicationToMavenLocal -PsnapshotNumber=${{ github.run_number }} -PgitRef=${{ github.ref }} |         run: ./gradlew publishLinuxX64PublicationToMavenLocal :jni:jvm:linux:publishJvmPublicationToMavenLocal -PsnapshotNumber=${{ github.run_number }} -PgitRef=${{ github.ref }} | ||||||
|       - name: Publish Windows |       - name: Publish Windows | ||||||
|         if: matrix.os == 'windows-latest' |         if: matrix.os == 'windows-latest' | ||||||
|         shell: msys2 {0} |         shell: msys2 {0} | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @ -101,7 +101,7 @@ jobs: | |||||||
|       - name: Check Linux |       - name: Check Linux | ||||||
|         if: matrix.os == 'ubuntu-latest' |         if: matrix.os == 'ubuntu-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
|         run: ./gradlew linuxTest |         run: ./gradlew linuxX64Test | ||||||
|       - name: Check iOS |       - name: Check iOS | ||||||
|         if: matrix.os == 'macOS-latest' |         if: matrix.os == 'macOS-latest' | ||||||
|         shell: bash |         shell: bash | ||||||
|  | |||||||
| @ -3,8 +3,8 @@ import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget | |||||||
| import org.jetbrains.dokka.Platform | import org.jetbrains.dokka.Platform | ||||||
| 
 | 
 | ||||||
| plugins { | plugins { | ||||||
|     kotlin("multiplatform") version "1.8.21" |     kotlin("multiplatform") version "1.9.21" | ||||||
|     id("org.jetbrains.dokka") version "1.8.10" |     id("org.jetbrains.dokka") version "1.9.10" | ||||||
|     `maven-publish` |     `maven-publish` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -16,13 +16,13 @@ buildscript { | |||||||
| 
 | 
 | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath("com.android.tools.build:gradle:7.3.1") |         classpath("com.android.tools.build:gradle:7.3.1") | ||||||
|         classpath("org.jetbrains.dokka:dokka-gradle-plugin:1.8.10") |         classpath("org.jetbrains.dokka:dokka-gradle-plugin:1.9.10") | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| allprojects { | allprojects { | ||||||
|     group = "fr.acinq.secp256k1" |     group = "fr.acinq.secp256k1" | ||||||
|     version = "0.12.1-SNAPSHOT" |     version = "0.13.0-SNAPSHOT" | ||||||
| 
 | 
 | ||||||
|     repositories { |     repositories { | ||||||
|         google() |         google() | ||||||
| @ -52,20 +52,22 @@ kotlin { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     val nativeMain by sourceSets.creating { dependsOn(commonMain) } |     val nativeMain by sourceSets.creating | ||||||
| 
 | 
 | ||||||
|     linuxX64("linux") { |     linuxX64 { | ||||||
|         secp256k1CInterop("host") |         secp256k1CInterop("host") | ||||||
|         compilations["main"].defaultSourceSet.dependsOn(nativeMain) |  | ||||||
|         // https://youtrack.jetbrains.com/issue/KT-39396 |  | ||||||
|         compilations["main"].kotlinOptions.freeCompilerArgs += listOf("-include-binary", "$rootDir/native/build/linux/libsecp256k1.a") |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ios { |     iosX64 { | ||||||
|  |         secp256k1CInterop("ios") | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     iosArm64 { | ||||||
|  |         secp256k1CInterop("ios") | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     iosSimulatorArm64 { | ||||||
|         secp256k1CInterop("ios") |         secp256k1CInterop("ios") | ||||||
|         compilations["main"].defaultSourceSet.dependsOn(nativeMain) |  | ||||||
|         // https://youtrack.jetbrains.com/issue/KT-39396 |  | ||||||
|         compilations["main"].kotlinOptions.freeCompilerArgs += listOf("-include-binary", "$rootDir/native/build/ios/libsecp256k1.a") |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     sourceSets.all { |     sourceSets.all { | ||||||
| @ -80,9 +82,9 @@ allprojects { | |||||||
|             val currentOs = OperatingSystem.current() |             val currentOs = OperatingSystem.current() | ||||||
|             val targets = when { |             val targets = when { | ||||||
|                 currentOs.isLinux -> listOf() |                 currentOs.isLinux -> listOf() | ||||||
|                 currentOs.isMacOsX -> listOf("linux") |                 currentOs.isMacOsX -> listOf("linuxX64") | ||||||
|                 currentOs.isWindows -> listOf("linux") |                 currentOs.isWindows -> listOf("linuxX64") | ||||||
|                 else -> listOf("linux") |                 else -> listOf("linuxX64") | ||||||
|             }.mapNotNull { kotlin.targets.findByName(it) as? KotlinNativeTarget } |             }.mapNotNull { kotlin.targets.findByName(it) as? KotlinNativeTarget } | ||||||
| 
 | 
 | ||||||
|             configure(targets) { |             configure(targets) { | ||||||
|  | |||||||
| @ -6,11 +6,10 @@ import fr.acinq.secp256k1.NativeSecp256k1 | |||||||
| import java.util.* | import java.util.* | ||||||
| 
 | 
 | ||||||
| public object NativeSecp256k1AndroidLoader { | public object NativeSecp256k1AndroidLoader { | ||||||
| 
 |  | ||||||
|     @JvmStatic |     @JvmStatic | ||||||
|     @Synchronized |     @Synchronized | ||||||
|     @Throws(Exception::class) |     @Throws(Exception::class) | ||||||
|     fun load(): Secp256k1 { |     public fun load(): Secp256k1 { | ||||||
|         try { |         try { | ||||||
|             System.loadLibrary("secp256k1-jni") |             System.loadLibrary("secp256k1-jni") | ||||||
|             return NativeSecp256k1 |             return NativeSecp256k1 | ||||||
| @ -27,5 +26,4 @@ public object NativeSecp256k1AndroidLoader { | |||||||
| 
 | 
 | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -9,7 +9,10 @@ cd secp256k1 | |||||||
| sh xconfigure.sh --enable-experimental --enable-module_ecdh --enable-module-recovery --enable-module-schnorrsig --enable-benchmark=no --enable-shared=no --enable-exhaustive-tests=no --enable-tests=no | sh xconfigure.sh --enable-experimental --enable-module_ecdh --enable-module-recovery --enable-module-schnorrsig --enable-benchmark=no --enable-shared=no --enable-exhaustive-tests=no --enable-tests=no | ||||||
| 
 | 
 | ||||||
| mkdir -p ../build/ios | mkdir -p ../build/ios | ||||||
| cp -v _build/universal/* ../build/ios/ | cp -v _build/universal/ios/* ../build/ios/ | ||||||
|  | 
 | ||||||
|  | mkdir -p ../build/iosSimulatorArm64 | ||||||
|  | cp -v _build/universal/iosSimulatorArm64/* ../build/iosSimulatorArm64/ | ||||||
| 
 | 
 | ||||||
| rm -rf _build | rm -rf _build | ||||||
| make clean | make clean | ||||||
|  | |||||||
| @ -69,9 +69,22 @@ HOST_FLAGS="${ARCH_FLAGS} -mios-simulator-version-min=${MIN_IOS_VERSION} -isysro | |||||||
| CHOST="x86_64-apple-darwin" | CHOST="x86_64-apple-darwin" | ||||||
| Build "$@" | Build "$@" | ||||||
| 
 | 
 | ||||||
|  | ## Build for iphone M1/M2/Mx simulators | ||||||
|  | SDK="iphonesimulator" | ||||||
|  | PLATFORM="arm64-sim" | ||||||
|  | PLATFORM_SIM_ARM=${PLATFORM} | ||||||
|  | ARCH_FLAGS="-arch arm64" | ||||||
|  | HOST_FLAGS="${ARCH_FLAGS} -mios-simulator-version-min=${MIN_IOS_VERSION} -isysroot $(xcrun --sdk ${SDK} --show-sdk-path)" | ||||||
|  | CHOST="arm-apple-darwin" | ||||||
|  | Build "$@" | ||||||
|  | 
 | ||||||
| # Create universal binary | # Create universal binary | ||||||
| cd "${PLATFORMS}/${PLATFORM_ARM}/lib" | cd "${PLATFORMS}/${PLATFORM_ARM}/lib" | ||||||
| LIB_NAME=`find . -iname *.a` | LIB_NAME=`find . -iname *.a` | ||||||
| cd - | cd - | ||||||
| mkdir -p "${UNIVERSAL}" &> /dev/null | mkdir -p "${UNIVERSAL}/ios" &> /dev/null | ||||||
| lipo -create -output "${UNIVERSAL}/${LIB_NAME}" "${PLATFORMS}/${PLATFORM_ARM}/lib/${LIB_NAME}" "${PLATFORMS}/${PLATFORM_ISIM}/lib/${LIB_NAME}" | mkdir -p "${UNIVERSAL}/iosSimulatorArm64" &> /dev/null | ||||||
|  | lipo -create -output "${UNIVERSAL}/ios/${LIB_NAME}" "${PLATFORMS}/${PLATFORM_ARM}/lib/${LIB_NAME}" "${PLATFORMS}/${PLATFORM_ISIM}/lib/${LIB_NAME}" | ||||||
|  | 
 | ||||||
|  | # create a specific library for arm64 simulator: it cannot be included in the lib above which already contains an arm64 lib | ||||||
|  | lipo -create -output "${UNIVERSAL}/iosSimulatorArm64/${LIB_NAME}" "${PLATFORMS}/${PLATFORM_SIM_ARM}/lib/${LIB_NAME}" | ||||||
| @ -21,9 +21,9 @@ mvn deploy:deploy-file -DrepositoryId=ossrh -Durl=https://oss.sonatype.org/conte | |||||||
|   -Djavadoc=$ARTIFACT_ID_BASE-$VERSION-javadoc.jar |   -Djavadoc=$ARTIFACT_ID_BASE-$VERSION-javadoc.jar | ||||||
| popd | popd | ||||||
| pushd . | pushd . | ||||||
| for i in iosarm64 iosx64 jni-android jni-common jni-jvm-darwin jni-jvm-extract jni-jvm-linux jni-jvm-mingw jni-jvm jvm linux; do | for i in iosarm64 iossimulatorarm64 iosx64 jni-android jni-common jni-jvm-darwin jni-jvm-extract jni-jvm-linux jni-jvm-mingw jni-jvm jvm linuxx64; do | ||||||
|   cd fr/acinq/secp256k1/secp256k1-kmp-$i/$VERSION |   cd fr/acinq/secp256k1/secp256k1-kmp-$i/$VERSION | ||||||
|   if [ $i == iosarm64 ] || [ $i == iosx64 ]; then |   if [ $i == iosarm64 ] || [ $i == iossimulatorarm64 ] || [ $i == iosx64 ]; then | ||||||
|     mvn deploy:deploy-file -DrepositoryId=ossrh -Durl=https://oss.sonatype.org/content/repositories/snapshots/ \ |     mvn deploy:deploy-file -DrepositoryId=ossrh -Durl=https://oss.sonatype.org/content/repositories/snapshots/ \ | ||||||
|       -DpomFile=$ARTIFACT_ID_BASE-$i-$VERSION.pom \ |       -DpomFile=$ARTIFACT_ID_BASE-$i-$VERSION.pom \ | ||||||
|       -Dfile=$ARTIFACT_ID_BASE-$i-$VERSION.klib \ |       -Dfile=$ARTIFACT_ID_BASE-$i-$VERSION.klib \ | ||||||
| @ -32,7 +32,7 @@ for i in iosarm64 iosx64 jni-android jni-common jni-jvm-darwin jni-jvm-extract j | |||||||
|       -Dclassifiers=metadata,,cinterop-libsecp256k1 \ |       -Dclassifiers=metadata,,cinterop-libsecp256k1 \ | ||||||
|       -Dsources=$ARTIFACT_ID_BASE-$i-$VERSION-sources.jar \ |       -Dsources=$ARTIFACT_ID_BASE-$i-$VERSION-sources.jar \ | ||||||
|       -Djavadoc=$ARTIFACT_ID_BASE-$i-$VERSION-javadoc.jar |       -Djavadoc=$ARTIFACT_ID_BASE-$i-$VERSION-javadoc.jar | ||||||
|   elif [ $i == linux ]; then |   elif [ $i == linuxx64 ]; then | ||||||
|     mvn deploy:deploy-file -DrepositoryId=ossrh -Durl=https://oss.sonatype.org/content/repositories/snapshots/ \ |     mvn deploy:deploy-file -DrepositoryId=ossrh -Durl=https://oss.sonatype.org/content/repositories/snapshots/ \ | ||||||
|       -DpomFile=$ARTIFACT_ID_BASE-$i-$VERSION.pom \ |       -DpomFile=$ARTIFACT_ID_BASE-$i-$VERSION.pom \ | ||||||
|       -Dfile=$ARTIFACT_ID_BASE-$i-$VERSION.klib \ |       -Dfile=$ARTIFACT_ID_BASE-$i-$VERSION.klib \ | ||||||
|  | |||||||
| @ -3,8 +3,12 @@ package = secp256k1 | |||||||
| headers = secp256k1.h secp256k1_ecdh.h secp256k1_recovery.h secp256k1_extrakeys.h secp256k1_schnorrsig.h | headers = secp256k1.h secp256k1_ecdh.h secp256k1_recovery.h secp256k1_extrakeys.h secp256k1_schnorrsig.h | ||||||
| headerFilter = secp256k1/** secp256k1_ecdh.h secp256k1_recovery.h secp256k1_extrakeys.h secp256k1_schnorrsig.h secp256k1.h | headerFilter = secp256k1/** secp256k1_ecdh.h secp256k1_recovery.h secp256k1_extrakeys.h secp256k1_schnorrsig.h secp256k1.h | ||||||
| 
 | 
 | ||||||
| libraryPaths.linux = c/secp256k1/build/linux/ | staticLibraries.linux = libsecp256k1.a | ||||||
|  | libraryPaths.linux = c/secp256k1/build/linux/ native/build/linux/ native/build/darwin/ | ||||||
| linkerOpts.linux = -L/usr/lib64 -L/usr/lib/x86_64-linux-gnu -L/usr/local/lib | linkerOpts.linux = -L/usr/lib64 -L/usr/lib/x86_64-linux-gnu -L/usr/local/lib | ||||||
| 
 | 
 | ||||||
| libraryPaths.ios = c/secp256k1/build/ios/ /usr/local/lib | staticLibraries.ios = libsecp256k1.a | ||||||
|  | libraryPaths.ios_x64 = c/secp256k1/build/ios/ /usr/local/lib native/build/ios/ | ||||||
|  | libraryPaths.ios_arm64 = c/secp256k1/build/ios/ /usr/local/lib native/build/ios/ | ||||||
|  | libraryPaths.ios_simulator_arm64 = c/secp256k1/build/ios/ /usr/local/lib native/build/iosSimulatorArm64/ | ||||||
| linkerOpts.ios = -framework Security -framework Foundation | linkerOpts.ios = -framework Security -framework Foundation | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ import kotlinx.cinterop.* | |||||||
| import platform.posix.size_tVar | import platform.posix.size_tVar | ||||||
| import secp256k1.* | import secp256k1.* | ||||||
| 
 | 
 | ||||||
| @OptIn(ExperimentalUnsignedTypes::class) | @OptIn(ExperimentalUnsignedTypes::class, ExperimentalForeignApi::class) | ||||||
| public object Secp256k1Native : Secp256k1 { | public object Secp256k1Native : Secp256k1 { | ||||||
| 
 | 
 | ||||||
|     private val ctx: CPointer<secp256k1_context> by lazy { |     private val ctx: CPointer<secp256k1_context> by lazy { | ||||||
| @ -238,7 +238,7 @@ public object Secp256k1Native : Secp256k1 { | |||||||
|             secp256k1_xonly_pubkey_parse(ctx, pubkey.ptr, nPub).requireSuccess("secp256k1_xonly_pubkey_parse() failed") |             secp256k1_xonly_pubkey_parse(ctx, pubkey.ptr, nPub).requireSuccess("secp256k1_xonly_pubkey_parse() failed") | ||||||
|             val nData = toNat(data) |             val nData = toNat(data) | ||||||
|             val nSig = toNat(signature) |             val nSig = toNat(signature) | ||||||
|             return secp256k1_schnorrsig_verify(ctx, nSig, nData, 32, pubkey.ptr) == 1 |             return secp256k1_schnorrsig_verify(ctx, nSig, nData, 32u, pubkey.ptr) == 1 | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -36,14 +36,14 @@ kotlin { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (includeAndroid) { |     if (includeAndroid) { | ||||||
|         android { |         androidTarget { | ||||||
|             compilations.all { |             compilations.all { | ||||||
|                 kotlinOptions.jvmTarget = "1.8" |                 kotlinOptions.jvmTarget = "1.8" | ||||||
|             } |             } | ||||||
|             sourceSets["androidMain"].dependencies { |             sourceSets["androidMain"].dependencies { | ||||||
|                 implementation(project(":jni:android")) |                 implementation(project(":jni:android")) | ||||||
|             } |             } | ||||||
|             sourceSets["androidTest"].dependencies { |             sourceSets["androidUnitTest"].dependencies { | ||||||
|                 implementation(kotlin("test-junit")) |                 implementation(kotlin("test-junit")) | ||||||
|                 implementation("androidx.test.ext:junit:1.1.2") |                 implementation("androidx.test.ext:junit:1.1.2") | ||||||
|                 implementation("androidx.test.espresso:espresso-core:3.3.0") |                 implementation("androidx.test.espresso:espresso-core:3.3.0") | ||||||
| @ -51,17 +51,18 @@ kotlin { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     linuxX64("linux") |     linuxX64() | ||||||
| 
 |     iosX64() | ||||||
|     ios() |     iosArm64() | ||||||
|  |     iosSimulatorArm64() | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| val includeAndroid = System.getProperty("includeAndroid")?.toBoolean() ?: true | val includeAndroid = System.getProperty("includeAndroid")?.toBoolean() ?: true | ||||||
| if (includeAndroid) { | if (includeAndroid) { | ||||||
|     extensions.configure<com.android.build.gradle.LibraryExtension>("android") { |     extensions.configure<com.android.build.gradle.LibraryExtension>("android") { | ||||||
|         defaultConfig { |         defaultConfig { | ||||||
|             compileSdkVersion(30) |             compileSdk =30 | ||||||
|             minSdkVersion(21) |             minSdk = 21 | ||||||
|             testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" |             testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user