diff options
author | Dmitry Jemerov <intelliyole@gmail.com> | 2015-07-13 18:54:14 +0200 |
---|---|---|
committer | Dmitry Jemerov <intelliyole@gmail.com> | 2015-07-13 18:54:14 +0200 |
commit | 1a79c5d46536f1140f6348868aa14974182114ba (patch) | |
tree | 19a27e45be309dfc3425088ce8db93811177b38f /gradle-plugin/src/main/kotlin/main.kt | |
parent | dfa23a3ff1b15570102d4431b7bfc709efa16a52 (diff) | |
parent | 0352d46db95ba375daa523bd5ec6e2f6b27f81f8 (diff) | |
download | dokka-1a79c5d46536f1140f6348868aa14974182114ba.tar.gz dokka-1a79c5d46536f1140f6348868aa14974182114ba.tar.bz2 dokka-1a79c5d46536f1140f6348868aa14974182114ba.zip |
Merge pull request #29 from cy6erGn0m/gradle-plugin
Gradle plugin
Diffstat (limited to 'gradle-plugin/src/main/kotlin/main.kt')
-rw-r--r-- | gradle-plugin/src/main/kotlin/main.kt | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/gradle-plugin/src/main/kotlin/main.kt b/gradle-plugin/src/main/kotlin/main.kt new file mode 100644 index 00000000..418af00f --- /dev/null +++ b/gradle-plugin/src/main/kotlin/main.kt @@ -0,0 +1,97 @@ +package org.jetbrains.dokka.gradle + +import groovy.lang.Closure +import org.gradle.api.DefaultTask +import org.gradle.api.Plugin +import org.gradle.api.Project +import org.gradle.api.plugins.JavaBasePlugin +import org.gradle.api.plugins.JavaPluginConvention +import org.gradle.api.tasks.SourceSet +import org.gradle.api.tasks.TaskAction +import org.jetbrains.dokka.DokkaGenerator +import org.jetbrains.dokka.SourceLinkDefinition +import java.io.File +import java.util.ArrayList + +public open class DokkaPlugin : Plugin<Project> { + override fun apply(project: Project) { + val ext = project.getExtensions().create("dokka", javaClass<DokkaExtension>()) + project.getTasks().create("dokka", javaClass<DokkaTask>()) + + ext.moduleName = project.getName() + ext.outputDirectory = File(project.getBuildDir(), "dokka").getAbsolutePath() + } +} + +public open class DokkaTask : DefaultTask() { + init { + setGroup(JavaBasePlugin.DOCUMENTATION_GROUP) + setDescription("Generates dokka documentation for Kotlin") + } + + TaskAction + fun generate() { + val project = getProject() + val conf = getProject().getExtensions().getByType(javaClass<DokkaExtension>()) + val javaPluginConvention = getProject().getConvention().getPlugin(javaClass<JavaPluginConvention>()) + + val sourceSets = javaPluginConvention.getSourceSets()?.findByName(SourceSet.MAIN_SOURCE_SET_NAME) + val sourceDirectories = sourceSets?.getAllSource()?.getSrcDirs()?.filter { it.exists() } ?: emptyList() + val allConfigurations = getProject().getConfigurations() + + val classpath = + conf.processConfigurations + .map { allConfigurations?.getByName(it) ?: throw IllegalArgumentException("No configuration $it found") } + .flatMap { it } + + if (sourceDirectories.isEmpty()) { + getLogger().warn("No source directories found: skipping dokka generation") + return + } + + DokkaGenerator( + DokkaGradleLogger(getLogger()), + classpath.map { it.getAbsolutePath() }, + sourceDirectories.map { it.getAbsolutePath() }, + conf.samples, + conf.includes, + conf.moduleName, + conf.outputDirectory, + conf.outputFormat, + conf.linkMappings.map { SourceLinkDefinition(project.file(it.dir).getAbsolutePath(), it.url, it.suffix) }, + false + ).generate() + } + +} + +public open class DokkaExtension { + var moduleName: String = "" + var outputFormat: String = "html" + var outputDirectory: String = "" + var processConfigurations: ArrayList<String> = arrayListOf("compile") + var includes: ArrayList<String> = arrayListOf() + var linkMappings: ArrayList<LinkMapping> = arrayListOf() + var samples: ArrayList<String> = arrayListOf() + + fun linkMapping(closure: Closure<Any?>) { + val mapping = LinkMapping() + closure.setDelegate(mapping) + closure.call() + + if (mapping.dir.isEmpty()) { + throw IllegalArgumentException("Link mapping should have dir") + } + if (mapping.url.isEmpty()) { + throw IllegalArgumentException("Link mapping should have url") + } + + linkMappings.add(mapping) + } +} + +public open class LinkMapping { + var dir: String = "" + var url: String = "" + var suffix: String? = null +} |