[kotlin-gradle-plugin] workaround for old k/n artifacts
This commit is contained in:
committed by
Stanislav Erokhin
parent
7ad656ea7f
commit
5c80dbfd4b
+41
-3
@@ -56,8 +56,46 @@ class NativeCompilerDownloader(
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Once we've decide to make K/N version like K one (with droppable maintenance 0), but this breaks old publications,
|
||||
* when did merging kotlin with kotlin/native after 1.5.0 release.
|
||||
* older 1.5.20?
|
||||
*/
|
||||
private fun CompilerVersion.toStringPre1_5_20(showMeta: Boolean, showBuild: Boolean) = buildString {
|
||||
if (major > 1
|
||||
|| minor > 5
|
||||
|| maintenance > 20
|
||||
)
|
||||
return toString(showMeta, showBuild)
|
||||
append(major)
|
||||
append('.')
|
||||
append(minor)
|
||||
if (maintenance != 0) {
|
||||
append('.')
|
||||
append(maintenance)
|
||||
}
|
||||
if (milestone != -1) {
|
||||
append("-M")
|
||||
append(milestone)
|
||||
}
|
||||
if (showMeta) {
|
||||
append('-')
|
||||
append(meta.metaString)
|
||||
}
|
||||
if (showBuild && build != -1) {
|
||||
append('-')
|
||||
append(build)
|
||||
}
|
||||
}
|
||||
|
||||
val versionStringRepresentation = compilerVersion.toStringPre1_5_20(
|
||||
compilerVersion.meta != MetaVersion.RELEASE,
|
||||
compilerVersion.meta != MetaVersion.RELEASE
|
||||
)
|
||||
|
||||
|
||||
private val dependencyNameWithVersion: String
|
||||
get() = "$dependencyName-$compilerVersion"
|
||||
get() = "$dependencyName-$versionStringRepresentation"
|
||||
|
||||
private val dependencyFileName: String
|
||||
get() = "$dependencyNameWithVersion.$archiveExtension"
|
||||
@@ -99,7 +137,7 @@ class NativeCompilerDownloader(
|
||||
val repoUrl = buildString {
|
||||
append("$BASE_DOWNLOAD_URL/")
|
||||
append(if (compilerVersion.meta == MetaVersion.DEV) "dev/" else "releases/")
|
||||
append("$compilerVersion/")
|
||||
append("$versionStringRepresentation/")
|
||||
append(simpleOsName)
|
||||
}
|
||||
val dependencyUrl = "$repoUrl/$dependencyFileName"
|
||||
@@ -109,7 +147,7 @@ class NativeCompilerDownloader(
|
||||
val compilerDependency = project.dependencies.create(
|
||||
mapOf(
|
||||
"name" to dependencyName,
|
||||
"version" to compilerVersion.toString(),
|
||||
"version" to versionStringRepresentation,
|
||||
"ext" to archiveExtension
|
||||
)
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user