Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kotools/samples

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.
https://github.com/kotools/samples

dokka gradle java kotlin

Last synced: 3 months ago
JSON representation

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.

Awesome Lists containing this project

README

        

# Kotools Samples

**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**.

This plugin also ensures that code samples are **inlined directly in the
documentation** and are **visible from the IDE**, enhancing the developer
experience.
Unlike many Kotlin libraries, such as Jetpack Compose, Kotools Samples ensures
your examples are not only available online but also accessible directly in the
IDE during development.

Currently, **Kotools Samples is not available yet**, but will **support the
Kotlin/JVM platform** starting from its first release.
**Kotlin Multiplatform support is planned for future releases**, allowing for
even more flexibility and broader application of the plugin.

## ⭐️ 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.

## 🧑‍💻 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:

```kotlin
// src/sample/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:

```java
// src/sample/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:

```kotlin
// 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!"
```

When you generate the documentation with Dokka, Kotools Samples will inline both
the Kotlin and Java examples directly in the documentation and automatically
restore the main sources afterward, ensuring that the examples do not pollute
your actual codebase.

![Screenshot](jvm-demo/screenshot.png)

## 🤝 Community

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

- [#kotools on Kotlin Slack](https://kotlinlang.slack.com/archives/C05H0L1LD25)

## 📣 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](https://github.com/LVMVRQUXL) for creating and sharing
this project with the open source community.

Thanks to all the [people that ever contributed](https://github.com/kotools/samples/graphs/contributors)
through code or other means such as bug reports, feature suggestions and so on.

## 📄 License

This project is licensed under the [MIT License](LICENSE.txt).

---

With **Kotools Samples**, you can provide **inlined, read-only code samples** in
**Kotlin or Java**, ensuring your documentation remains accurate, visible, and
reliable both online and in the IDE.
Stay tuned for the **first release of Kotools Samples with Kotlin/JVM support**,
and **Kotlin Multiplatform support** in future releases!