536 lines
15 KiB
Plaintext
Raw Normal View History

2020-05-24 11:12:00 +02:00
/*
* Copyright 2019 Ugljesa Jovanovic
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
@file:Suppress("UnstableApiUsage")
import org.jetbrains.kotlin.gradle.targets.js.testing.KotlinJsTest
import org.jetbrains.kotlin.gradle.targets.native.tasks.KotlinNativeTest
import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget
2020-05-24 11:12:00 +02:00
plugins {
kotlin(PluginsDeps.multiplatform)
id(PluginsDeps.mavenPublish)
id(PluginsDeps.signing)
id(PluginsDeps.node) version Versions.nodePlugin
id(PluginsDeps.dokka) version Versions.dokkaPlugin
2020-05-24 11:12:00 +02:00
}
val sonatypeStaging = "https://oss.sonatype.org/service/local/staging/deploy/maven2/"
val sonatypeSnapshots = "https://oss.sonatype.org/content/repositories/snapshots/"
val sonatypePassword: String? by project
2020-05-24 11:12:00 +02:00
val sonatypeUsername: String? by project
2020-05-24 11:12:00 +02:00
val sonatypePasswordEnv: String? = System.getenv()["SONATYPE_PASSWORD"]
val sonatypeUsernameEnv: String? = System.getenv()["SONATYPE_USERNAME"]
2020-05-24 11:12:00 +02:00
repositories {
mavenCentral()
jcenter()
}
group = ReleaseInfo.group
version = ReleaseInfo.version
val ideaActive = isInIdea()
println("Idea active: $ideaActive")
2020-05-24 11:12:00 +02:00
kotlin {
val hostOsName = getHostOsName()
2020-05-31 20:36:06 +02:00
runningOnLinuxx86_64 {
println("Configuring Linux X86-64 targets")
2020-05-24 11:12:00 +02:00
jvm()
js {
browser {
testTask {
enabled = true //Until I sort out testing on travis
useKarma {
useChrome()
}
2020-05-24 11:12:00 +02:00
}
}
nodejs {
testTask {
useMocha() {
timeout = "10s"
}
}
}
}
linuxX64("linux") {
binaries {
staticLib {
}
}
}
2020-05-31 21:19:52 +02:00
}
2020-05-24 11:12:00 +02:00
2020-06-01 11:29:45 +02:00
//Not supported in OFFICIAL coroutines at the moment (we're running a custom build)
runningOnLinuxArm64 {
println("Configuring Linux Arm 64 targets")
2020-05-31 21:19:52 +02:00
linuxArm64() {
binaries {
staticLib {
}
}
}
2020-06-01 11:29:45 +02:00
}
2020-06-01 11:29:45 +02:00
runningOnLinuxArm32 {
println("Configuring Linux Arm 32 targets")
2020-06-01 11:29:45 +02:00
linuxArm32Hfp() {
binaries {
staticLib {
}
}
}
2020-05-24 11:12:00 +02:00
}
runningOnMacos {
println("Configuring macos targets")
2020-05-31 21:19:52 +02:00
iosX64() {
binaries {
framework {
optimized = true
}
}
}
2020-05-31 21:19:52 +02:00
iosArm64() {
binaries {
framework {
optimized = true
}
}
}
2020-05-31 21:19:52 +02:00
iosArm32() {
binaries {
framework {
optimized = true
}
}
}
2020-05-24 11:12:00 +02:00
macosX64() {
binaries {
framework {
optimized = true
}
}
}
tvosX64() {
binaries {
framework {
optimized = true
}
}
}
tvosArm64() {
binaries {
framework {
optimized = true
}
}
}
watchosArm64() {
binaries {
framework {
optimized = true
}
}
}
watchosArm32() {
binaries {
framework {
optimized = true
}
}
}
watchosX86() {
binaries {
framework {
optimized = true
}
}
}
2020-05-24 11:12:00 +02:00
}
runningOnWindows {
println("Configuring Mingw targets")
2020-05-24 11:12:00 +02:00
mingwX64() {
binaries {
staticLib {
optimized = true
}
}
}
}
println(targets.names)
sourceSets {
val commonMain by getting {
dependencies {
implementation(kotlin(Deps.Common.stdLib))
implementation(kotlin(Deps.Common.test))
implementation(Deps.Common.coroutines)
implementation(Deps.Common.kotlinBigNum)
2020-05-24 20:41:32 +02:00
api(project(Deps.Common.apiProject))
2020-05-24 11:12:00 +02:00
}
}
val commonTest by getting {
dependencies {
implementation(kotlin(Deps.Common.test))
implementation(kotlin(Deps.Common.testAnnotation))
}
}
val nativeDependencies = independentDependencyBlock {
implementation(Deps.Native.coroutines)
}
val nativeMain by creating {
dependsOn(commonMain)
dependencies {
nativeDependencies(this)
2020-05-24 11:12:00 +02:00
}
}
val nativeTest by creating {
dependsOn(commonTest)
dependencies {
implementation(Deps.Native.coroutines)
2020-05-24 11:12:00 +02:00
}
}
targets.withType<KotlinNativeTarget> {
println("Target $name")
compilations.getByName("main") {
if ((this@withType.name.contains("ios") || this@withType.name.contains("tvos") || this@withType.name.contains("watchos")).not()) {
defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
println("Setting cinterop for $this")
2020-05-28 23:53:37 +02:00
val libsodiumCinterop by cinterops.creating {
defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
compilerOpts.add("-I${project.rootDir}/sodiumWrapper/include/")
}
kotlinOptions.freeCompilerArgs = listOf(
"-include-binary", "${project.rootDir}/sodiumWrapper/lib/libsodium.a"
)
2020-05-24 11:12:00 +02:00
}
if (this@withType.name.contains("ios") || this@withType.name.contains("tvos") || this@withType.name.contains("watchos")) {
defaultSourceSet.dependsOn(createWorkaroundNativeMainSourceSet(this@withType.name, nativeDependencies))
println("Setting ios cinterop for $this")
val libsodiumCinterop by cinterops.creating {
defFile(project.file("src/nativeInterop/cinterop/libsodium.def"))
2020-05-30 23:24:45 +02:00
compilerOpts.add("-I${project.rootDir}/sodiumWrapper/ios-include/")
}
kotlinOptions.freeCompilerArgs = listOf(
2020-05-30 23:24:45 +02:00
"-include-binary", "${project.rootDir}/sodiumWrapper/ios-lib/libsodium.a"
)
}
2020-05-28 23:47:15 +02:00
2020-05-24 11:12:00 +02:00
}
compilations.getByName("test") {
println("Setting native test dep for $this@withType.name")
defaultSourceSet.dependsOn(nativeTest)
2020-05-28 23:47:15 +02:00
2020-05-24 11:12:00 +02:00
}
}
2020-05-31 21:19:52 +02:00
runningOnLinuxx86_64 {
println("Configuring Linux 64 Bit source sets")
2020-05-24 11:12:00 +02:00
val jvmMain by getting {
dependencies {
implementation(kotlin(Deps.Jvm.stdLib))
implementation(kotlin(Deps.Jvm.test))
implementation(kotlin(Deps.Jvm.testJUnit))
implementation(Deps.Jvm.coroutinesCore)
}
}
val jvmTest by getting {
dependencies {
implementation(kotlin(Deps.Jvm.test))
implementation(kotlin(Deps.Jvm.testJUnit))
implementation(Deps.Jvm.coroutinesTest)
implementation(kotlin(Deps.Jvm.reflection))
}
}
val jsMain by getting {
dependencies {
implementation(kotlin(Deps.Js.stdLib))
implementation(Deps.Js.coroutines)
2020-05-26 00:23:27 +02:00
implementation(npm(Deps.Js.Npm.libsodium.first, Deps.Js.Npm.libsodium.second))
implementation(npm(Deps.Js.Npm.libsodiumWrappers.first, Deps.Js.Npm.libsodiumWrappers.second))
2020-05-24 11:12:00 +02:00
}
}
val jsTest by getting {
dependencies {
implementation(Deps.Js.coroutines)
implementation(kotlin(Deps.Js.test))
2020-05-26 00:23:27 +02:00
implementation(npm(Deps.Js.Npm.libsodium.first, Deps.Js.Npm.libsodium.second))
2020-05-24 11:12:00 +02:00
}
}
val linuxMain by getting {
dependsOn(nativeMain)
isRunningInIdea {
kotlin.srcDir("src/nativeMain/kotlin")
}
2020-05-24 11:12:00 +02:00
}
val linuxTest by getting {
dependsOn(nativeTest)
isRunningInIdea {
kotlin.srcDir("src/nativeTest/kotlin")
}
2020-05-24 11:12:00 +02:00
}
}
runningOnMacos {
println("Configuring Macos source sets")
2020-05-24 11:12:00 +02:00
val macosX64Main by getting {
dependsOn(nativeMain)
if (ideaActive) {
kotlin.srcDir("src/nativeMain/kotlin")
}
2020-05-24 11:12:00 +02:00
}
val macosX64Test by getting {
dependsOn(nativeTest)
if (ideaActive) {
kotlin.srcDir("src/nativeTest/kotlin")
}
2020-05-24 11:12:00 +02:00
}
val tvosX64Main by getting {
dependsOn(commonMain)
}
val tvosArm64Main by getting {
dependsOn(commonMain)
}
val watchosX86Main by getting {
dependsOn(commonMain)
}
val watchosArm64Main by getting {
dependsOn(commonMain)
}
val watchosArm32Main by getting {
dependsOn(commonMain)
}
2020-05-24 11:12:00 +02:00
}
if (hostOsName == "windows") {
val mingwX64Main by getting {
dependsOn(nativeMain)
if (ideaActive) {
kotlin.srcDir("src/nativeMain/kotlin")
2020-05-24 11:12:00 +02:00
}
}
val mingwX64Test by getting {
dependsOn(nativeTest)
if (ideaActive) {
kotlin.srcDir("src/nativeTest/kotlin")
}
2020-05-24 11:12:00 +02:00
}
}
all {
languageSettings.enableLanguageFeature("InlineClasses")
}
}
}
task<Copy>("copyPackageJson") {
dependsOn("compileKotlinJs")
println("Copying package.json from $projectDir/core/src/jsMain/npm")
from("$projectDir/src/jsMain/npm")
2020-05-24 11:12:00 +02:00
println("Node modules dir ${node.nodeModulesDir}")
into("${node.nodeModulesDir}")
2020-05-24 11:12:00 +02:00
}
tasks {
create<Jar>("javadocJar") {
dependsOn(dokka)
archiveClassifier.set("javadoc")
from(dokka.get().outputDirectory)
}
dokka {
println("Dokka !")
2020-05-24 11:12:00 +02:00
impliedPlatforms = mutableListOf("Common")
kotlinTasks {
listOf()
}
sourceRoot {
println("Common !")
path =
"/home/ionspin/Projects/Future/kotlin-multiplatform-crypto/crypto/src/commonMain" //TODO remove static path!
2020-05-24 11:12:00 +02:00
platforms = listOf("Common")
}
}
2020-05-31 21:19:52 +02:00
if (getHostOsName() == "linux" && getHostArchitecture() == "x86-64") {
2020-05-24 11:12:00 +02:00
val jvmTest by getting(Test::class) {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
}
}
val linuxTest by getting(KotlinNativeTest::class) {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
2020-05-24 17:24:32 +02:00
showStandardStreams = true
2020-05-24 11:12:00 +02:00
}
}
val jsNodeTest by getting(KotlinJsTest::class) {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
2020-05-24 17:24:32 +02:00
// showStandardStreams = true
2020-05-24 11:12:00 +02:00
}
}
// val legacyjsNodeTest by getting(KotlinJsTest::class) {
//
// testLogging {
// events("PASSED", "FAILED", "SKIPPED")
// showStandardStreams = true
// }
// }
// val jsIrBrowserTest by getting(KotlinJsTest::class) {
// testLogging {
// events("PASSED", "FAILED", "SKIPPED")
// showStandardStreams = true
// }
// }
}
if (getHostOsName() == "windows") {
val mingwX64Test by getting(KotlinNativeTest::class) {
testLogging {
events("PASSED", "FAILED", "SKIPPED")
showStandardStreams = true
}
}
}
}
signing {
isRequired = false
sign(publishing.publications)
}
publishing {
publications.withType(MavenPublication::class) {
artifact(tasks["javadocJar"])
pom {
name.set("Kotlin Multiplatform Crypto")
description.set("Kotlin Multiplatform Crypto library")
url.set("https://github.com/ionspin/kotlin-multiplatform-crypto")
licenses {
license {
name.set("The Apache License, Version 2.0")
url.set("http://www.apache.org/licenses/LICENSE-2.0.txt")
}
}
developers {
developer {
id.set("ionspin")
name.set("Ugljesa Jovanovic")
email.set("opensource@ionspin.com")
}
}
scm {
url.set("https://github.com/ionspin/kotlin-multiplatform-crypto")
connection.set("scm:git:git://git@github.com:ionspin/kotlin-multiplatform-crypto.git")
developerConnection.set("scm:git:ssh://git@github.com:ionspin/kotlin-multiplatform-crypto.git")
}
}
}
repositories {
maven {
url = uri(sonatypeStaging)
credentials {
username = sonatypeUsername ?: sonatypeUsernameEnv ?: ""
password = sonatypePassword ?: sonatypePasswordEnv ?: ""
}
}
maven {
name = "snapshot"
url = uri(sonatypeSnapshots)
credentials {
username = sonatypeUsername ?: sonatypeUsernameEnv ?: ""
password = sonatypePassword ?: sonatypePasswordEnv ?: ""
}
}
}
}
2020-05-24 17:24:32 +02:00
//configurations.forEach {
//
// if (it.name == "linuxCompileKlibraries") {
// println("Configuration name: ${it.name}")
// it.attributes {
// this.keySet().forEach { key ->
// val attribute = getAttribute(key)
// println(" |-- Attribute $key ${attribute}")
// attribute(org.jetbrains.kotlin.gradle.plugin.ProjectLocalConfigurations.ATTRIBUTE, "publicZ")
// }
// }
// }
//}
2020-05-24 11:12:00 +02:00