Skip to content

Gradle plugin that inlines read-only Kotlin and Java code samples into Dokka documentation, ensuring they are always correct and visible not only online but also in IDEs.

License

Notifications You must be signed in to change notification settings

kotools/samples

Repository files navigation

Kotools Samples

Latest Gradle Kotlin Dokka

Kotools Samples is a Gradle plugin designed to help Kotlin library authors integrate read-only, non-editable samples into their documentation using Dokka. It addresses a limitation in Dokka, which does not allow making code samples non-editable or non-executable.

⭐️ Key Features

  • Readonly inlined code samples: Displays your examples inlined in the documentation, ensuring they are non-editable and non-executable, preventing unwanted modification or execution.
  • Kotlin or Java support: Write your code samples in either Kotlin or Java, providing flexibility to serve a broader range of developers.
  • Sample visibility in IDE: Unlike many libraries (such as Jetpack Compose), Kotools Samples makes your examples visible within the IDE (e.g., IntelliJ IDEA, Android Studio), enhancing accessibility and usability during development.
  • Always correct samples: Ensures your examples are always up-to-date by compiling them alongside your main and test sources. Any breaking changes in your codebase will trigger compilation errors, prompting you to update the examples.
  • Kotlin/JVM support: Fully supports the Kotlin/JVM platform, with Kotlin Multiplatform support in future releases.
  • Seamless integration: Works effortlessly with Kotlin, Java, and Dokka, smoothly integrating into your Gradle build process.

🛠️ Installation

For adding Kotools Samples to your Kotlin/JVM project, it is recommended to use the Gradle plugins DSL in Kotlin. Just replace the $version variable by the latest version or by another one available in the changelog.

plugins {
  id("org.kotools.samples.jvm") version "$version"
}

See this plugin on the Gradle Plugin Portal for more installation options.

🧑‍💻 Usage example

Kotools Samples ensures that your code samples are integrated into your documentation without affecting your main sources. When generating the documentation with Dokka, the plugin temporarily modifies the main sources to inline the samples, and restores them afterward to avoid polluting the main codebase. This process is transparent and automatic.

Here's a Kotlin sample:

// src/test/kotlin/HelloKotlinSample.kt

import kotlin.test.Test
import kotlin.test.assertEquals

class HelloKotlinSample {
    @Test
    fun greet() {
        val name = "Sample"
        val greeting: String = greet(name)
        val expected = "Hello $name!"
        assertEquals(expected, greeting)
    }
}

And a Java sample:

// src/test/java/HelloJavaSample.java

import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;

class HelloJavaSample {
    @Test
    void greet() {
        final String name = "Sample";
        final String greeting = HelloKt.greet(name);
        final String expected = "Hello %s!".formatted(name);
        Assertions.assertEquals(expected, greeting);
    }
}

Reference these samples in your Dokka documentation:

// src/main/kotlin/Hello.kt

/**
 * Greets the user with the specified [name].
 *
 * Here's an example of calling this function from Kotlin code:
 *
 * SAMPLE: [HelloKotlinSample.greet]
 *
 * Here's an example of calling this function from Java code:
 *
 * SAMPLE: [HelloJavaSample.greet]
 */
fun greet(name: String = "World"): String = "Hello $name!"

Here's the resulting documentation generated by Dokka with Kotools Samples:

Screenshot

Please note that samples located in the sample Kotlin source set are still supported in this version, but this source set will be removed in the future (see issue #18).

📝 Documentation

Here's additional documentation for learning more about this project:

🤝 Community

Join our thriving community! Connect, share insights, and collaborate with fellow developers to make Kotools Samples even more powerful.

📣 Show Your Support

If you find this project valuable, show your support by giving us a ⭐️ on GitHub. Your feedback and engagement mean the world to us!

🚧 Contributing

Contributions are welcome! Feel free to submit bug reports, feature requests, or pull requests to improve the plugin.

🙏 Acknowledgements

Thanks to Loïc Lamarque for creating and sharing this project with the open source community.

Thanks to all the people that ever contributed through code or other means such as bug reports, feature suggestions and so on.

📄 License

This project is licensed under the MIT License.

About

Gradle plugin that inlines read-only Kotlin and Java code samples into Dokka documentation, ensuring they are always correct and visible not only online but also in IDEs.

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Contributors 3

  •  
  •  
  •