mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-25 15:40:28 +08:00
Fix build
This commit is contained in:
parent
fd438c2e4c
commit
85600d35b0
@ -28,7 +28,7 @@ import net.mamoe.mirai.console.plugin.loader.PluginLoadException
|
|||||||
import net.mamoe.mirai.console.plugin.loader.PluginLoader
|
import net.mamoe.mirai.console.plugin.loader.PluginLoader
|
||||||
import net.mamoe.mirai.console.plugin.name
|
import net.mamoe.mirai.console.plugin.name
|
||||||
import net.mamoe.mirai.console.util.CoroutineScopeUtils.childScope
|
import net.mamoe.mirai.console.util.CoroutineScopeUtils.childScope
|
||||||
import net.mamoe.mirai.console.util.SemVersion.Companion.contains
|
import net.mamoe.mirai.console.util.SemVersion
|
||||||
import net.mamoe.mirai.utils.info
|
import net.mamoe.mirai.utils.info
|
||||||
import java.io.File
|
import java.io.File
|
||||||
import java.nio.file.Path
|
import java.nio.file.Path
|
||||||
@ -248,8 +248,8 @@ internal fun List<PluginDescription>.findDependency(dependency: PluginDependency
|
|||||||
}
|
}
|
||||||
|
|
||||||
internal fun PluginDescription.checkSatisfies(dependency: PluginDependency, plugin: PluginDescription) {
|
internal fun PluginDescription.checkSatisfies(dependency: PluginDependency, plugin: PluginDescription) {
|
||||||
val requirement = dependency.versionRequirement
|
val requirement = dependency.versionRequirement ?: return
|
||||||
if (requirement != null && this.version !in requirement) {
|
if (SemVersion.parseRangeRequirement(requirement).test(this.version)) {
|
||||||
throw PluginLoadException("Plugin '${plugin.id}' ('${plugin.id}') requires '${dependency.id}' with version $requirement while the resolved is ${this.version}")
|
throw PluginLoadException("Plugin '${plugin.id}' ('${plugin.id}') requires '${dependency.id}' with version $requirement while the resolved is ${this.version}")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,7 @@ import net.mamoe.mirai.console.util.SemVersion
|
|||||||
* @see PluginDescription.dependencies
|
* @see PluginDescription.dependencies
|
||||||
*/
|
*/
|
||||||
@Serializable(with = PluginDependency.PluginDependencyAsStringSerializer::class)
|
@Serializable(with = PluginDependency.PluginDependencyAsStringSerializer::class)
|
||||||
public class PluginDependency @JvmOverloads constructor(
|
public data class PluginDependency @JvmOverloads constructor(
|
||||||
/**
|
/**
|
||||||
* 依赖插件 ID, [PluginDescription.id]
|
* 依赖插件 ID, [PluginDescription.id]
|
||||||
*/
|
*/
|
||||||
@ -37,7 +37,7 @@ public class PluginDependency @JvmOverloads constructor(
|
|||||||
*
|
*
|
||||||
* @see SemVersion.Requirement
|
* @see SemVersion.Requirement
|
||||||
*/
|
*/
|
||||||
public val versionRequirement: SemVersion.Requirement? = null,
|
public val versionRequirement: String? = null,
|
||||||
/**
|
/**
|
||||||
* 若为 `false`, 插件在找不到此依赖时也能正常加载.
|
* 若为 `false`, 插件在找不到此依赖时也能正常加载.
|
||||||
*/
|
*/
|
||||||
@ -63,32 +63,12 @@ public class PluginDependency @JvmOverloads constructor(
|
|||||||
|
|
||||||
public override fun toString(): String = buildString {
|
public override fun toString(): String = buildString {
|
||||||
append(id)
|
append(id)
|
||||||
versionRequirement?.rule?.let(::append)
|
versionRequirement?.let(::append)
|
||||||
if (isOptional) {
|
if (isOptional) {
|
||||||
append('?')
|
append('?')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override fun equals(other: Any?): Boolean {
|
|
||||||
if (this === other) return true
|
|
||||||
if (javaClass != other?.javaClass) return false
|
|
||||||
|
|
||||||
other as PluginDependency
|
|
||||||
|
|
||||||
if (id != other.id) return false
|
|
||||||
if (versionRequirement?.rule != other.versionRequirement?.rule) return false
|
|
||||||
if (isOptional != other.isOptional) return false
|
|
||||||
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
public override fun hashCode(): Int {
|
|
||||||
var result = id.hashCode()
|
|
||||||
result = 31 * result + (versionRequirement?.rule?.hashCode() ?: 0)
|
|
||||||
result = 31 * result + isOptional.hashCode()
|
|
||||||
return result
|
|
||||||
}
|
|
||||||
|
|
||||||
public companion object {
|
public companion object {
|
||||||
/**
|
/**
|
||||||
* 解析 "$id:$versionRequirement?"
|
* 解析 "$id:$versionRequirement?"
|
||||||
@ -101,7 +81,7 @@ public class PluginDependency @JvmOverloads constructor(
|
|||||||
val (id, version) = string.removeSuffix("?").let {
|
val (id, version) = string.removeSuffix("?").let {
|
||||||
it.substringBeforeLast(':') to it.substringAfterLast(':', "")
|
it.substringBeforeLast(':') to it.substringAfterLast(':', "")
|
||||||
}
|
}
|
||||||
return PluginDependency(id, SemVersion.parseRangeRequirement(version), optional)
|
return PluginDependency(id, version, optional)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,20 +191,6 @@ public class JvmPluginDescriptionBuilder(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* isOptional = false
|
|
||||||
*
|
|
||||||
* @see PluginDependency
|
|
||||||
*/
|
|
||||||
@ILoveKuriyamaMiraiForever
|
|
||||||
public fun dependsOn(
|
|
||||||
@ResolveContext(PLUGIN_ID) pluginId: String,
|
|
||||||
versionRequirement: SemVersion.Requirement,
|
|
||||||
isOptional: Boolean = false,
|
|
||||||
): JvmPluginDescriptionBuilder = apply {
|
|
||||||
this.dependencies.add(PluginDependency(pluginId, versionRequirement, isOptional))
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see PluginDependency
|
* @see PluginDependency
|
||||||
*/
|
*/
|
||||||
@ -214,7 +200,7 @@ public class JvmPluginDescriptionBuilder(
|
|||||||
@ResolveContext(VERSION_REQUIREMENT) versionRequirement: String,
|
@ResolveContext(VERSION_REQUIREMENT) versionRequirement: String,
|
||||||
isOptional: Boolean = false,
|
isOptional: Boolean = false,
|
||||||
): JvmPluginDescriptionBuilder = apply {
|
): JvmPluginDescriptionBuilder = apply {
|
||||||
this.dependencies.add(PluginDependency(pluginId, SemVersion.parseRangeRequirement(versionRequirement), isOptional))
|
this.dependencies.add(PluginDependency(pluginId, versionRequirement, isOptional))
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -255,7 +241,7 @@ public class JvmPluginDescriptionBuilder(
|
|||||||
internal data class SimpleJvmPluginDescription
|
internal data class SimpleJvmPluginDescription
|
||||||
@JvmOverloads constructor(
|
@JvmOverloads constructor(
|
||||||
override val id: String,
|
override val id: String,
|
||||||
override val name: String = id,
|
override val name: String,
|
||||||
override val version: SemVersion,
|
override val version: SemVersion,
|
||||||
override val author: String = "",
|
override val author: String = "",
|
||||||
override val info: String = "",
|
override val info: String = "",
|
||||||
|
@ -10,6 +10,6 @@
|
|||||||
package net.mamoe.mirai.console.gradle
|
package net.mamoe.mirai.console.gradle
|
||||||
|
|
||||||
internal object VersionConstants {
|
internal object VersionConstants {
|
||||||
const val CONSOLE_VERSION = "1.0-RC-1" // value is written here automatically during build
|
const val CONSOLE_VERSION = "1.0-RC2-dev-1" // value is written here automatically during build
|
||||||
const val CORE_VERSION = "1.3.3" // value is written here automatically during build
|
const val CORE_VERSION = "1.3.3" // value is written here automatically during build
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user