From 893dd637e3727d455e82f72ff90e823c6e017f7a Mon Sep 17 00:00:00 2001 From: Paweł Marks Date: Mon, 25 Nov 2019 15:48:08 +0100 Subject: Cache for plugin stubs --- core/src/main/kotlin/plugability/DokkaContext.kt | 12 +++++++++--- core/src/main/kotlin/plugability/DokkaPlugin.kt | 11 +++++------ 2 files changed, 14 insertions(+), 9 deletions(-) (limited to 'core/src') diff --git a/core/src/main/kotlin/plugability/DokkaContext.kt b/core/src/main/kotlin/plugability/DokkaContext.kt index 7727329c..a5bcd695 100644 --- a/core/src/main/kotlin/plugability/DokkaContext.kt +++ b/core/src/main/kotlin/plugability/DokkaContext.kt @@ -5,6 +5,7 @@ import java.io.File import java.net.URLClassLoader import java.util.* import kotlin.reflect.KClass +import kotlin.reflect.full.createInstance interface DokkaContext { operator fun > get(point: E): List> @@ -35,13 +36,18 @@ private class DokkaContextConfigurationImpl( ) : DokkaContext, DokkaContextConfiguration { private val plugins = mutableMapOf, DokkaPlugin>() + private val pluginStubs = mutableMapOf, DokkaPlugin>() + internal val extensions = mutableMapOf, MutableList>>() @Suppress("UNCHECKED_CAST") override operator fun > get(point: E) = extensions[point] as List> @Suppress("UNCHECKED_CAST") - override fun plugin(kclass: KClass) = plugins[kclass] as T + override fun plugin(kclass: KClass) = (plugins[kclass] ?: pluginStubFor(kclass)) as T + + private fun pluginStubFor(kclass: KClass): DokkaPlugin = + pluginStubs.getOrPut(kclass) { kclass.createInstance().also { it.context = this } } fun install(plugin: DokkaPlugin) { plugins[plugin::class] = plugin @@ -59,8 +65,8 @@ private class DokkaContextConfigurationImpl( val loadedListForDebug = extensions.run { keys + values.flatten() }.toList() .joinToString(prefix = "[\n", separator = ",\n", postfix = "\n]") { "\t$it" } - logger.progress("Loaded plugins: ${pluginNames}") - logger.progress("Loaded: ${loadedListForDebug}") + logger.progress("Loaded plugins: $pluginNames") + logger.progress("Loaded: $loadedListForDebug") } } diff --git a/core/src/main/kotlin/plugability/DokkaPlugin.kt b/core/src/main/kotlin/plugability/DokkaPlugin.kt index 663cf88e..7a968b8b 100644 --- a/core/src/main/kotlin/plugability/DokkaPlugin.kt +++ b/core/src/main/kotlin/plugability/DokkaPlugin.kt @@ -3,7 +3,6 @@ package org.jetbrains.dokka.plugability import kotlin.properties.ReadOnlyProperty import kotlin.reflect.KProperty import kotlin.reflect.KProperty1 -import kotlin.reflect.full.createInstance private typealias ExtensionDelegate = ReadOnlyProperty> @@ -13,8 +12,8 @@ abstract class DokkaPlugin { @PublishedApi internal var context: DokkaContext? = null - protected inline fun plugin(): T = - context?.plugin(T::class) ?: T::class.createInstance().also { it.context = this.context } + protected inline fun plugin(): T = context?.plugin(T::class) + ?: throw IllegalStateException("Querying about plugins is only possible with dokka context initialised") protected fun extensionPoint() = object : ReadOnlyProperty> { @@ -24,9 +23,9 @@ abstract class DokkaPlugin { ) } - protected fun extending(definition: ExtendingDSL.() -> Extension) = ExtensionProvider(definition) + protected fun extending(definition: ExtendingDSL.() -> Extension) = ExtensionProvider(definition) - protected class ExtensionProvider internal constructor( + protected class ExtensionProvider internal constructor( private val definition: ExtendingDSL.() -> Extension ) { operator fun provideDelegate(thisRef: DokkaPlugin, property: KProperty<*>) = lazy { @@ -39,7 +38,7 @@ abstract class DokkaPlugin { internal fun internalInstall(ctx: DokkaContextConfiguration) { extensionDelegates.asSequence() - .filterIsInstance>>() // always true + .filterIsInstance>>() // should be always true .map { it.get(this) } .forEach { ctx.addExtension(it) } } -- cgit