com.jetbrains.plugin.structure.intellij.problems.MinorWarnings.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of structure-intellij Show documentation
Show all versions of structure-intellij Show documentation
Library for parsing JetBrains IDE plugins. Can be used to verify that plugin complies with JetBrains Marketplace requirements.
The newest version!
/*
* Copyright 2000-2020 JetBrains s.r.o. and other contributors. Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE file.
*/
package com.jetbrains.plugin.structure.intellij.problems
import com.jetbrains.plugin.structure.base.problems.InvalidDescriptorProblem
import com.jetbrains.plugin.structure.base.problems.PluginDescriptorResolutionError
import com.jetbrains.plugin.structure.base.problems.PluginProblem
import com.jetbrains.plugin.structure.base.problems.ProblemSolutionHint
import com.jetbrains.plugin.structure.intellij.version.IdeVersion
class NoModuleDependencies(descriptorPath: String) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = "The plugin configuration file does not include any module dependency tags. So, the plugin is " +
"assumed to be a legacy plugin and is loaded only in IntelliJ IDEA. Please note that plugins should " +
"declare a dependency on `com.intellij.modules.platform` to indicate dependence on shared functionality."
) {
override val level
get() = Level.WARNING
override val hint = ProblemSolutionHint(
documentationUrl = "https://plugins.jetbrains.com/docs/intellij/plugin-compatibility.html"
)
}
class DefaultChangeNotes(descriptorPath: String) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = "The change-notes parameter contains the default value 'Add change notes here' or 'most HTML tags may be used'."
) {
override val level
get() = Level.WARNING
}
class TemplateWordInPluginName(
descriptorPath: String,
pluginName: String,
templateWord: String
) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = "The plugin name '$pluginName' should not include the word '$templateWord'."
) {
override val level
get() = Level.WARNING
}
class TemplateWordInPluginId(
descriptorPath: String,
pluginId: String,
templateWord: String
) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = "The plugin ID '$pluginId' should not include the word '$templateWord'."
) {
override val level
get() = Level.WARNING
}
class OptionalDependencyDescriptorResolutionProblem(
private val dependencyId: String,
private val configurationFile: String,
private val errors: List
) : PluginProblem() {
override val level
get() = Level.WARNING
override val message: String
get() {
val descriptorResolutionError = errors.filterIsInstance().firstOrNull()
val prefix = "The configuration file '$configurationFile' for optional dependency '$dependencyId'"
return if (descriptorResolutionError != null) {
"$prefix failed to be resolved: ${descriptorResolutionError.message}"
} else {
prefix + " is invalid: ${errors.joinToString { it.message }}"
}
}
}
class ModuleDescriptorResolutionProblem(
private val moduleName: String,
private val configurationFile: String,
private val errors: List
) : PluginProblem() {
override val level
get() = Level.WARNING
override val message: String
get() {
val descriptorResolutionError = errors.filterIsInstance().firstOrNull()
val prefix = "The configuration file '$configurationFile' for module '$moduleName'"
return if (descriptorResolutionError != null) {
"$prefix failed to be resolved: ${descriptorResolutionError.message}"
} else {
prefix + " is invalid: ${errors.joinToString { it.message }}"
}
}
}
data class DuplicatedDependencyWarning(val dependencyId: String) : PluginProblem() {
override val level
get() = Level.WARNING
override val message: String
get() = "There is a duplicated dependency on '$dependencyId'. Remove this dependency by updating the plugin.xml file."
}
class SuperfluousNonOptionalDependencyDeclaration(private val dependencyId: String) : PluginProblem() {
override val level
get() = Level.WARNING
override val message
get() = "Dependency declaration $dependencyId is superfluous. " +
"Dependencies are mandatory by default. Update the plugin.xml file and remove optional=\"false\" attribute " +
"from the dependency parameters."
}
class OptionalDependencyConfigFileNotSpecified(private val optionalDependencyId: String) : PluginProblem() {
override val level
get() = Level.WARNING
override val message
get() = "Optional dependency declaration on '$optionalDependencyId' should specify \"config-file\". Declare " +
"config-file attribute in addition to optional dependency in the plugin.xml file."
}
class ElementAvailableOnlySinceNewerVersion(
private val elementName: String,
private val availableSinceBuild: IdeVersion,
private val pluginSinceBuild: IdeVersion,
private val pluginUntilBuild: IdeVersion?
) : PluginProblem() {
override val level
get() = Level.WARNING
override val message
get() = "The <$elementName> element is available only since ${availableSinceBuild.asStringWithoutProductCode()} " +
"but the plugin can be installed in " +
if (pluginUntilBuild != null) {
pluginSinceBuild.asStringWithoutProductCode() + "—" + pluginUntilBuild.asStringWithoutProductCode() + "."
} else {
pluginSinceBuild.asStringWithoutProductCode() + "+."
}
}
class ElementMissingAttribute(
private val elementName: String,
private val attributeName: String
) : PluginProblem() {
override val level
get() = Level.WARNING
override val message
get() = "The <$elementName> element must specify attribute $attributeName. To define an application-level listener, " +
"add the section to your plugin.xml along with and attributes."
}
open class SuspiciousUntilBuild(
private val untilBuild: String,
private val additionalMessage: String = ""
) : PluginProblem() {
override val hint = ProblemSolutionHint(
documentationUrl = "https://plugins.jetbrains.com/docs/intellij/build-number-ranges.html"
)
override val message: String
get() = "The '$untilBuild' does not represent the actual build number. " +
if (additionalMessage.isNotBlank()) "$additionalMessage " else "" +
"If you want your plugin to be compatible with all future IDE versions, you can remove this attribute. " +
"However, we highly recommend setting it to the latest available IDE version."
override val level
get() = Level.WARNING
}
open class NonexistentReleaseInUntilBuild(
untilBuild: String,
nonexistentRelease: String = ""
) : SuspiciousUntilBuild(untilBuild, "Version '$nonexistentRelease' does not exist")
class ForbiddenPluginIdPrefix(
descriptorPath: String,
pluginId: String,
prefix: String
) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = "The plugin ID '$pluginId' has a prefix '$prefix' that is not allowed."
) {
override val level
get() = Level.WARNING
override val hint = ProblemSolutionHint(
documentationUrl = "https://plugins.jetbrains.com/docs/intellij/plugin-configuration-file.html#idea-plugin__id"
)
}
class UnknownServiceClientValue(descriptorPath: String, serviceClient: String) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = "Plugin has unknown service client value: '$serviceClient'"
) {
override val level
get() = Level.WARNING
}
/**
* @see [K2IdeModeCompatibilityVerifier]
*/
private const val UNDECLARED_KOTLIN_K2_COMPATIBILITY_MODE_MESSAGE = "Plugin depends on the Kotlin plugin (org.jetbrains.kotlin) but does not declare " +
"a compatibility mode in the extension. " +
"This feature is available for IntelliJ IDEA 2024.2.1 or later."
data class UndeclaredKotlinK2CompatibilityMode(val descriptorPath: String) : InvalidDescriptorProblem(
descriptorPath = descriptorPath,
detailedMessage = UNDECLARED_KOTLIN_K2_COMPATIBILITY_MODE_MESSAGE
) {
val detailedMessage = UNDECLARED_KOTLIN_K2_COMPATIBILITY_MODE_MESSAGE
override val level
get() = Level.WARNING
override val hint = ProblemSolutionHint(
" ",
"https://kotlin.github.io/analysis-api/migrating-from-k1.html#declaring-compatibility-with-the-k2-kotlin-mode"
)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy