R3Conclave / dokka

Documentation Engine for Kotlin

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Conclave Dokka fork

Why do we fork Dokka?

We do fork Dokka as we need to patch the issues affecting our documentation. We experimented with the latest version of Dokka (1.7.10 Beta as of 14/09/22), but it doesn't bring many improvements from the current issues. Even problems with logo were noticed. Therefore, it was decided that only update to 1.5.31 Alpha will be done at this stage.

What has been fixed?

Each fix is a separate commit in the 'conclave-changes' branch of https://github.com/R3Conclave/dokka, and consists of:

  1. Dokka includes a setting named 'includeNonPublic' which default to false. In this configuration only public members are published to documentation. However, protected members form part of the interface and should be included. Setting this to true results in the protected members being visible but also all private members. Our change groups public and protected together when 'includeNonPublic' is false.
  2. The Dokka setting, 'suppressObviousFunctions' removes methods such as hashCode and toString from the documentation but leaves obvious properties in place. Our patch removes these from the documentation.
  3. Dokka filters were not being run on Enum values resulting in obvious functions/properties being present in the documentation.
  4. If a function is provided for a getter/setter for a property then the documentation for the getter/setter was not being generated.
  5. Added translation for some basic JVM types that were left as Kotlin types during the conversion to Java documentation, including void, int, long and byte[].
  6. Update class template for javadoc to include a missing marker that is required for IDE integration.
  7. On "See also" sections, don't try to show the FQN. Instead, use the link name. This is because the 'hack' to get the FQN in docker misses off the target if it is a method or property.
  8. Fix "See also" links to companion objects that were unresolved.
  9. Workaround issue where the @JvmStatic annotation was not being resolved by the compiler. This should really be investigated and fixed properly by resolving the reference but the workaround works for now.
  10. Modify 'isObvious' logic to allow FAKE_OVERRIDE methods to be documented otherwise inherited non-obvious methods are hidden.
  11. In class summary page, always show full documentation rather than just first sentence.
  12. Rename "Functions" to "Methods".
  13. Hide 'final' modifier from functions.

Using the R3 dokka version

The Conclave SDK root gradle project refers to the dokka plugin, therefore the plugin itself cannot be built as part of the build script. Instead, dokka is published to artifactory and artifacts are used as required.

Modifying and building a new version.

New version is built in TeamCity and published to conclave-maven artifactory repository.

Dokka official JetBrains project TeamCity (build status)

Dokka is a documentation engine for Kotlin, performing the same function as javadoc for Java. Just like Kotlin itself, Dokka fully supports mixed-language Java/Kotlin projects. It understands standard Javadoc comments in Java files and KDoc comments in Kotlin files, and can generate documentation in multiple formats including standard Javadoc, HTML and Markdown.

Using Dokka

Full documentation is available at https://kotlin.github.io/dokka/1.5.0/

Using the Gradle plugin

Note: If you are upgrading from 0.10.x to a current release of Dokka, please have a look at our migration guide

The preferred way is to use plugins block.

build.gradle.kts:

plugins {
    id("org.jetbrains.dokka") version "1.5.0"
}

repositories {
    mavenCentral()
}

The plugin adds dokkaHtml, dokkaJavadoc, dokkaGfm and dokkaJekyll tasks to the project.

Applying plugins

Dokka plugin creates Gradle configuration for each output format in the form of dokka${format}Plugin:

dependencies {
    dokkaHtmlPlugin("org.jetbrains.dokka:kotlin-as-java-plugin:1.5.0")
}

You can also create a custom Dokka task and add plugins directly inside:

val customDokkaTask by creating(DokkaTask::class) {
    dependencies {
        plugins("org.jetbrains.dokka:kotlin-as-java-plugin:1.5.0")
    }
}

Please note that dokkaJavadoc task will properly document only single jvm source set

To generate the documentation, use the appropriate dokka${format} Gradle task:

./gradlew dokkaHtml

Please see the Dokka Gradle example project for an example.

We encourage users to create their own plugins and share them with the community on official plugins list.

Android

Make sure you apply Dokka after com.android.library and kotlin-android.

buildscript {
    dependencies {
        classpath("org.jetbrains.kotlin:kotlin-gradle-plugin:${kotlin_version}")
        classpath("org.jetbrains.dokka:dokka-gradle-plugin:${dokka_version}")
    }
}
repositories {
    mavenCentral()
}
apply(plugin= "com.android.library")
apply(plugin= "kotlin-android")
apply(plugin= "org.jetbrains.dokka")
dokkaHtml.configure {
    dokkaSourceSets {
        named("main") {
            noAndroidSdkLink.set(false)
        }
    }
}

Multi-module projects

For documenting Gradle multi-module projects, you can use dokka${format}Multimodule tasks.

tasks.dokkaHtmlMultiModule.configure {
    outputDirectory.set(buildDir.resolve("dokkaCustomMultiModuleOutput"))
}

DokkaMultiModule depends on all Dokka tasks in the subprojects, runs them, and creates a toplevel page with links to all generated (sub)documentations

Using the Maven plugin

The Maven plugin does not support multi-platform projects.

Documentation is by default generated in target/dokka.

The following goals are provided by the plugin:

  • dokka:dokka - generate HTML documentation in Dokka format (showing declarations in Kotlin syntax)
  • dokka:javadoc - generate HTML documentation in Javadoc format (showing declarations in Java syntax)
  • dokka:javadocJar - generate a .jar file with Javadoc format documentation

Applying plugins

You can add plugins inside the dokkaPlugins block:

<plugin>
    <groupId>org.jetbrains.dokka</groupId>
    <artifactId>dokka-maven-plugin</artifactId>
    <version>${dokka.version}</version>
    <executions>
        <execution>
            <phase>pre-site</phase>
            <goals>
                <goal>dokka</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <dokkaPlugins>
            <plugin>
                <groupId>org.jetbrains.dokka</groupId>
                <artifactId>kotlin-as-java-plugin</artifactId>
                <version>${dokka.version}</version>
            </plugin>
        </dokkaPlugins>
    </configuration>
</plugin>

Please see the Dokka Maven example project for an example.

Using the Command Line

To run Dokka from the command line, download the Dokka CLI runner. To generate documentation, run the following command:

java -jar dokka-cli.jar <arguments>

You can also use a JSON file with dokka configuration:

java -jar <dokka_cli.jar> <path_to_config.json>

Output formats

Dokka documents Java classes as seen in Kotlin by default, with javadoc format being the only exception.

  • html - HTML format used by default
  • javadoc - looks like JDK's Javadoc, Kotlin classes are translated to Java
  • gfm - GitHub flavored markdown
  • jekyll - Jekyll compatible markdown

If you want to generate the documentation as seen from Java perspective, you can add the kotlin-as-java plugin to the Dokka plugins classpath, eg. in Gradle:

dependencies {
    implementation("...")
    dokkaGfmPlugin("org.jetbrains.dokka:kotlin-as-java-plugin:${dokka-version}")
}

FAQ

If you encounter any problems, please see the FAQ.

About

Documentation Engine for Kotlin

License:Apache License 2.0


Languages

Language:Kotlin 96.9%Language:CSS 1.2%Language:JavaScript 0.9%Language:TypeScript 0.7%Language:SCSS 0.2%Language:Java 0.1%Language:Shell 0.0%