aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--runners/maven-plugin/src/main/kotlin/DokkaMojo.kt230
1 files changed, 101 insertions, 129 deletions
diff --git a/runners/maven-plugin/src/main/kotlin/DokkaMojo.kt b/runners/maven-plugin/src/main/kotlin/DokkaMojo.kt
index ca3a65fd..650f268f 100644
--- a/runners/maven-plugin/src/main/kotlin/DokkaMojo.kt
+++ b/runners/maven-plugin/src/main/kotlin/DokkaMojo.kt
@@ -14,23 +14,23 @@ import org.jetbrains.dokka.*
import java.io.File
import java.net.URL
-class SourceLinkMapItem : DokkaConfiguration.SourceLinkDefinition {
+class SourceLinkMapItem {
@Parameter(name = "path", required = true)
- override var path: String = ""
+ var path: String = ""
@Parameter(name = "url", required = true)
- override var url: String = ""
+ var url: String = ""
@Parameter(name = "lineSuffix")
- override var lineSuffix: String? = null
+ var lineSuffix: String? = null
}
-class ExternalDocumentationLink : DokkaConfiguration.ExternalDocumentationLink {
+class ExternalDocumentationLinkBuilder : DokkaConfiguration.ExternalDocumentationLink.Builder() {
@Parameter(name = "url", required = true)
- override var url: URL = URL("")
+ override var url: URL? = null
@Parameter(name = "packageListUrl", required = true)
- override var packageListUrl: URL = URL("")
+ override var packageListUrl: URL? = null
}
abstract class AbstractDokkaMojo : AbstractMojo() {
@@ -52,178 +52,150 @@ abstract class AbstractDokkaMojo : AbstractMojo() {
override var suppress: Boolean = false
}
- class Multiplatform : DokkaConfiguration.PassConfiguration {
- @Parameter(required = true, defaultValue = "\${project.compileSourceRoots}")
- var sourceDirectories: List<String> = emptyList()
-
- @Parameter(required = true, defaultValue = "\${project.artifactId}")
- override var moduleName: String = ""
-
- @Parameter(required = true, defaultValue = "\${project.compileClasspathElements}")
- override var classpath: List<String> = emptyList()
-
- @Parameter
- override var sourceRoots: List<SourceRoot> = emptyList()
+ @Parameter(required = true, defaultValue = "\${project.compileSourceRoots}")
+ var sourceDirectories: List<String> = emptyList()
- @Parameter
- override val samples: List<String> = emptyList()
+ @Parameter
+ var sourceRoots: List<SourceRoot> = emptyList()
- @Parameter
- override val includes: List<String> = emptyList()
+ @Parameter
+ var samples: List<String> = emptyList()
- @Parameter
- override val includeNonPublic: Boolean = false
+ @Parameter
+ var includes: List<String> = emptyList()
- @Parameter
- override val includeRootPackage: Boolean = false
+ @Parameter(required = true, defaultValue = "\${project.compileClasspathElements}")
+ var classpath: List<String> = emptyList()
- @Parameter
- override val reportUndocumented: Boolean = true
- @Parameter
- override val skipEmptyPackages: Boolean = true
+ @Parameter
+ var sourceLinks: List<SourceLinkMapItem> = emptyList()
- @Parameter
- override val skipDeprecated: Boolean = false
+ @Parameter(required = true, defaultValue = "\${project.artifactId}")
+ var moduleName: String = ""
- @Parameter(required = false, defaultValue = "6")
- override var jdkVersion: Int = 6
+ @Parameter(required = false, defaultValue = "false")
+ var skip: Boolean = false
- @Parameter
- override val sourceLinks: List<SourceLinkMapItem> = emptyList()
+ @Parameter(required = false, defaultValue = "6")
+ var jdkVersion: Int = 6
- @Parameter
- override val perPackageOptions: List<PackageOptions> = emptyList()
+ @Parameter
+ var skipDeprecated: Boolean = false
+ @Parameter
+ var skipEmptyPackages: Boolean = true
+ @Parameter
+ var reportUndocumented: Boolean = true
- @Parameter
- override val externalDocumentationLinks: List<ExternalDocumentationLink> = emptyList()
+ @Parameter
+ var impliedPlatforms: List<String> = emptyList()
- @Parameter
- override val languageVersion: String? = null
+ @Parameter
+ var perPackageOptions: List<PackageOptions> = emptyList()
- @Parameter
- override val apiVersion: String? = null
+ @Parameter
+ var externalDocumentationLinks: List<ExternalDocumentationLinkBuilder> = emptyList()
- @Parameter(defaultValue = "false")
- override var noStdlibLink: Boolean = false
+ @Parameter(defaultValue = "false")
+ var noStdlibLink: Boolean = false
- @Parameter(defaultValue = "false")
- override var noJdkLink: Boolean = false
+ @Parameter(defaultValue = "false")
+ var noJdkLink: Boolean = false
- @Parameter
- override val suppressedFiles: List<String> = emptyList()
+ @Parameter
+ var cacheRoot: String? = null
- @Parameter
- override val collectInheritedExtensionsFromLibraries: Boolean = false
+ @Parameter
+ var languageVersion: String? = null
- override var analysisPlatform: Platform = Platform.DEFAULT
+ @Parameter
+ var apiVersion: String? = null
- @Parameter
- val platform: String = ""
+ @Parameter
+ var includeRootPackage: Boolean = false
- @Parameter
- override val targets: List<String> = emptyList()
+ @Parameter
+ var suppressedFiles: List<String> = emptyList()
- @Parameter
- override val sinceKotlin: String = "1.0"
- }
+ @Parameter
+ var collectInheritedExtensionsFromLibraries: Boolean = false
@Parameter
- var multiplatform: List<Multiplatform> = emptyList()
+ var platform: String = ""
@Parameter
- var config: Multiplatform? = null
+ var targets: List<String> = emptyList()
- @Parameter(required = true, defaultValue = "\${project.artifactId}")
- var moduleName: String = ""
+ @Parameter
+ var sinceKotlin: String = "1.0"
@Parameter
- var impliedPlatforms: List<String> = emptyList() //TODO check
+ var includeNonPublic: Boolean = false
@Parameter
- var cacheRoot: String? = null
+ var generateIndexPages: Boolean = false
protected abstract fun getOutDir(): String
protected abstract fun getOutFormat(): String
- @Parameter(required = false, defaultValue = "false")
- var skip: Boolean = false
-
- @Parameter(required = true, defaultValue = "\${project.compileClasspathElements}")
- var classpath: List<String> = emptyList()
-
- //TODO remove
- @Parameter(required = true, defaultValue = "\${project.compileSourceRoots}")
- var sourceDirectories: List<String> = emptyList()
- @Parameter(required = false, defaultValue = "6")
- val jdkVersion: Int = 6
- @Parameter(defaultValue = "false")
- val noStdlibLink: Boolean = false
- @Parameter(defaultValue = "false")
- val noJdkLink: Boolean = false
-
override fun execute() {
if (skip) {
log.info("Dokka skip parameter is true so no dokka output will be produced")
return
}
- val passConfigurationList = (
- if (multiplatform.isEmpty() && config != null) listOf(config!!) else multiplatform
- ).map {
- defaultPassConfiguration(it)
- }
-
- passConfigurationList.flatMap { it.sourceLinks }.forEach {
+ sourceLinks.forEach {
if (it.path.contains("\\")) {
throw MojoExecutionException("Incorrect path property, only Unix based path allowed.")
}
}
- val platforms = impliedPlatforms
- val cacheRoot = cacheRoot
-
- val configuration = object : DokkaConfiguration {
- override val outputDir = getOutDir()
- override val format = getOutFormat()
- override val impliedPlatforms = platforms
- override val cacheRoot = cacheRoot
- override val passesConfigurations = passConfigurationList
- override val generateIndexPages = false // TODO: Should we implement this?
- }
+ val passConfiguration = PassConfigurationImpl(
+ classpath = classpath,
+ sourceRoots = sourceDirectories.map { SourceRootImpl(it) } + sourceRoots.map { SourceRootImpl(path = it.path) },
+ samples = samples,
+ includes = includes,
+ collectInheritedExtensionsFromLibraries = collectInheritedExtensionsFromLibraries, // TODO: Should we implement this?
+ sourceLinks = sourceLinks.map { SourceLinkDefinitionImpl(it.path, it.url, it.lineSuffix) },
+ jdkVersion = jdkVersion,
+ skipDeprecated = skipDeprecated,
+ skipEmptyPackages = skipEmptyPackages,
+ reportUndocumented = reportUndocumented,
+ perPackageOptions = perPackageOptions.map {
+ PackageOptionsImpl(
+ prefix = it.prefix,
+ includeNonPublic = it.includeNonPublic,
+ reportUndocumented = it.reportUndocumented,
+ skipDeprecated = it.skipDeprecated,
+ suppress = it.suppress
+ )},
+ externalDocumentationLinks = externalDocumentationLinks.map { it.build() as ExternalDocumentationLinkImpl },
+ noStdlibLink = noStdlibLink,
+ noJdkLink = noJdkLink,
+ languageVersion = languageVersion,
+ apiVersion = apiVersion,
+ moduleName = moduleName,
+ suppressedFiles = suppressedFiles, // TODO: Should we implement this?
+ sinceKotlin = sinceKotlin, // TODO: Should we implement this?
+ analysisPlatform = if (platform.isNotEmpty()) Platform.fromString(platform) else Platform.DEFAULT, // TODO: Should we implement this?
+ targets = targets, // TODO: Should we implement this?
+ includeNonPublic = includeNonPublic, // TODO: Should we implement this?
+ includeRootPackage = includeRootPackage // TODO: Should we implement this?
+ )
+
+ val configuration = DokkaConfigurationImpl(
+ outputDir = getOutDir(),
+ format = getOutFormat(),
+ impliedPlatforms = impliedPlatforms,
+ cacheRoot = cacheRoot,
+ passesConfigurations = listOf(passConfiguration),
+ generateIndexPages = generateIndexPages // TODO: Should we implement this?
+ )
val gen = DokkaGenerator(configuration, MavenDokkaLogger(log))
gen.generate()
}
-
- private fun defaultPassConfiguration(passConfig: Multiplatform): Multiplatform {
- passConfig.moduleName = moduleName
- passConfig.classpath = classpath
- passConfig.externalDocumentationLinks.map {
- val builder = DokkaConfiguration.ExternalDocumentationLink.Builder(it.url, it.packageListUrl)
- builder.build()
- }
- if(passConfig.platform.isNotEmpty()){
- passConfig.analysisPlatform = Platform.fromString(passConfig.platform)
- }
- // TODO fix
- passConfig.sourceRoots = sourceDirectories.map {
- val sourceRoot = SourceRoot()
- sourceRoot.path = it
- sourceRoot
- } + passConfig.sourceRoots
- passConfig.jdkVersion = jdkVersion
- passConfig.noStdlibLink = noStdlibLink
- passConfig.noJdkLink = noJdkLink
-// passConfig.sourceRoots = passConfig.sourceDirectories.map {
-// val sourceRoot = SourceRoot()
-// sourceRoot.path = it
-// sourceRoot
-// } + passConfig.sourceRoots
-
- return passConfig
- }
}
@Mojo(name = "dokka", defaultPhase = LifecyclePhase.PRE_SITE, threadSafe = true, requiresDependencyResolution = ResolutionScope.COMPILE, requiresProject = true)