Releases: Jolanrensen/KoDEx
Releases · Jolanrensen/KoDEx
v0.4.0: /** KoDEx */
What's Changed
- Dokka 2.0.0 for the Gradle Plugin
- IDE highlighting ✨ by @Jolanrensen in #56
- Large refactor! Take care ;)
- renaming docProcessor package to kodex by @Jolanrensen in #58
- Releasing KoDEx IntelliJ plugin on the marketplace! https://plugins.jetbrains.com/plugin/26250---kodex---kotlin-documentation-extensions
Full Changelog: v0.4.0-beta1...v0.4.0
v0.4.0-beta1
What's Changed
- K2 mode intellij by @Jolanrensen in #51
- Updating Dokka to 2.0.0(-Beta) by @Jolanrensen in #53
- Better ide support by @Jolanrensen in #55
- Type alias support! You can now refer to KDocs on type aliases and use the doc preprocessor inside KDocs on type aliases too.
This is a beta version until Dokka 2.0.0 is released.
Full Changelog: v0.3.10...v0.4.0-beta1
v0.3.10
What's Changed
- outputReadOnly parameter for html output and normal output. by @Jolanrensen in #50
Full Changelog: v0.3.9...v0.3.10
v0.3.9
What's Changed
@file:ExcludeFromSources
support by @Jolanrensen in #49
Full Changelog: v0.3.8...v0.3.9
v0.3.8
Full Changelog: v0.3.7...v0.3.8
v0.3.7
v0.3.6
What's Changed
- changed
outputs.upToDateWhen {}
to be more relaxed. The Gradle plugin should run less often and only when needed - Gradle output attempts to be read only
Full Changelog: v0.3.5...v0.3.6
v0.3.5
What's Changed
- Performance by Include dependency graph by @Jolanrensen in #45
Full Changelog: v0.3.4...v0.3.5
- Doc processors can now run in parallel (enabled by default in TagDocProcessor with
canProcessParallel
). This is disabled for@include
to prevent concurrent modifications. - Include can now pre-sort docs (can be disabled by setting the argument
INCLUDE_DOC_PROCESSOR_PRE_SORT
to false) before running. This analyses the docs in O(n), creates a dependency graph which then outputs an order in such a way that each doc can be rendered in one go, O(n) again. This is different from before where some parts of text could be processed multiple times. In practice or with smaller code bases, the performance could be worse with pre-sorting (as all docs now have to be analysed twice), but in larger code bases you might notice a difference. - Generating a dependency graph is done by
IncludeDocAnalyzer
, aTagDocAnalyser
which is the same as aTagDocProcessor
but without changing the docs. - Added speed indicators to the lifecycle of the gradle plugin.
- The most interesting part now is the IntelliJ plugin. I wanted to have support for the "rendered docs" feature of IntelliJ which could display, well, rendered docs right next to the code. However, since the plugin works one doc at a time, this very quickly became very slow. So, I changed
DocumentablesByPathWithCache
to an advanced caching system, taking track of changes in a doc + doc@include
dependencies with a dependency graph again. I cache both the doc content results (the final rendered doc), as well as a post-include state. This post-include state cache is to prevent deep@include
paths with many queries and just overall less work, similar to pre-sort for the gradle plugin.
The result is a way faster experience, especially when you're not modifying code (it can just load the cache) and, when "Render all doc comments" is enabled, you can modify one doc and see (relatively) live results in docs dependent on it!
v0.3.4
v0.3.3
What's Changed
- Performance by @Jolanrensen in #43 Can in some cases halve the processing time!
Full Changelog: v0.3.2...v0.3.3