main.io.github.smiley4.schemakenerator.reflection.steps.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of schema-kenerator-reflection Show documentation
Show all versions of schema-kenerator-reflection Show documentation
Kotlin library for automatically generating various schemas - analyzes types using reflection
package io.github.smiley4.schemakenerator.reflection
import io.github.smiley4.schemakenerator.core.data.BaseTypeData
import io.github.smiley4.schemakenerator.core.data.Bundle
import io.github.smiley4.schemakenerator.core.data.PrimitiveTypeData
import io.github.smiley4.schemakenerator.core.data.PropertyType
import io.github.smiley4.schemakenerator.reflection.data.EnumConstType
import io.github.smiley4.schemakenerator.reflection.steps.ReflectionAnnotationSubTypeStep
import io.github.smiley4.schemakenerator.reflection.steps.ReflectionTypeProcessingStep
import io.github.smiley4.schemakenerator.reflection.steps.ReflectionTypeProcessingStep.Companion.DEFAULT_PRIMITIVE_TYPES
import kotlin.reflect.KClass
import kotlin.reflect.KType
import kotlin.reflect.typeOf
/**
* See [ReflectionAnnotationSubTypeStep]
*/
fun KType.collectSubTypes(maxRecursionDepth: Int = 10): Bundle {
return ReflectionAnnotationSubTypeStep(
maxRecursionDepth = maxRecursionDepth
).process(this)
}
class ReflectionTypeProcessingStepConfig {
var customProcessors = mutableMapOf, () -> BaseTypeData>()
var typeRedirects = mutableMapOf().also { it.putAll(ReflectionTypeProcessingStep.DEFAULT_REDIRECTS) }
/**
* Whether to include getters as members of classes (see [PropertyType.GETTER]).
*/
var includeGetters: Boolean = false
/**
* Whether to include weak getters as members of classes (see [PropertyType.WEAK_GETTER]).
*/
var includeWeakGetters: Boolean = false
/**
* Whether to include functions as members of classes (see [PropertyType.FUNCTION]).
*/
var includeFunctions: Boolean = false
/**
* Whether to include hidden (e.g. private) members
*/
var includeHidden: Boolean = false
/**
* Whether to include static members
*/
var includeStatic: Boolean = false
/**
* The list of types that are considered "primitive types" and returned as [PrimitiveTypeData]
*/
var primitiveTypes: MutableSet> = DEFAULT_PRIMITIVE_TYPES.toMutableSet()
/**
* Whether to use toString for enum values or the declared name
*/
var enumConstType: EnumConstType = EnumConstType.NAME
/**
* Add a custom processor for the given type that overwrites the default behaviour
*/
fun customProcessor(type: KClass<*>, processor: () -> BaseTypeData) {
customProcessors[type] = processor
}
/**
* Add a custom processor for the given type that overwrites the default behaviour
*/
inline fun customProcessor(noinline processor: () -> BaseTypeData) {
customProcessor(typeOf().classifier!! as KClass<*>, processor)
}
/**
* Add custom processors for given type that overwrites the default behaviour
*/
fun customProcessors(processors: Map, () -> BaseTypeData>) {
customProcessors.putAll(processors)
}
/**
* Redirect from the given type to the other given type, i.e. when the "from" type is processed, the "to" type is used instead.
*/
fun redirect(from: KType, to: KType) {
typeRedirects[from] = to
}
/**
* Redirect from the given type to the other given type, i.e. when the "from" type is processed, the "to" type is used instead.
*/
inline fun redirect() {
redirect(typeOf(), typeOf())
}
/**
* Redirect from the given types to the other given types, i.e. when a type is processed, the associated type is used instead.
*/
fun redirect(redirects: Map) {
typeRedirects.putAll(redirects)
}
}
/**
* See [ReflectionTypeProcessingStep]
*/
fun KType.processReflection(configBlock: ReflectionTypeProcessingStepConfig.() -> Unit = {}): Bundle {
val config = ReflectionTypeProcessingStepConfig().apply(configBlock)
return ReflectionTypeProcessingStep(
includeGetters = config.includeGetters,
includeWeakGetters = config.includeWeakGetters,
includeFunctions = config.includeFunctions,
includeHidden = config.includeHidden,
includeStatic = config.includeStatic,
primitiveTypes = config.primitiveTypes,
customProcessors = config.customProcessors,
enumConstType = config.enumConstType,
typeRedirects = config.typeRedirects
).process(this)
}
/**
* See [ReflectionTypeProcessingStep]
*/
fun Bundle.processReflection(configBlock: ReflectionTypeProcessingStepConfig.() -> Unit = {}): Bundle {
val config = ReflectionTypeProcessingStepConfig().apply(configBlock)
return ReflectionTypeProcessingStep(
includeGetters = config.includeGetters,
includeWeakGetters = config.includeWeakGetters,
includeFunctions = config.includeFunctions,
includeHidden = config.includeHidden,
includeStatic = config.includeStatic,
primitiveTypes = config.primitiveTypes,
customProcessors = config.customProcessors,
enumConstType = config.enumConstType,
typeRedirects = config.typeRedirects
).process(this)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy