package org.jetbrains.dokka import ru.yole.jkid.CustomSerializer import ru.yole.jkid.ValueSerializer import ru.yole.jkid.deserialization.JKidException import java.io.Serializable import java.net.URL class UrlSerializer : ValueSerializer { override fun fromJsonValue(jsonValue: Any?): URL? { if (jsonValue !is String?) throw JKidException("Expected string representation of URL, got: $jsonValue") return jsonValue?.let { URL(jsonValue) } } override fun toJsonValue(value: URL?): Any? = value?.toExternalForm() } enum class Platform(val key: String) { jvm("jvm"), js("js"), common("common"); companion object { val DEFAULT = jvm fun fromString(key: String): Platform { return when (key.toLowerCase()) { jvm.key -> jvm js.key -> js common.key -> common else -> TODO("write normal exception") } } } } interface DokkaConfiguration { val outputDir: String val format: String val generateIndexPages: Boolean val cacheRoot: String? val passesConfigurations: List val impliedPlatforms: List interface PassConfiguration { val moduleName: String val classpath: List val sourceRoots: List val samples: List val includes: List val includeNonPublic: Boolean val includeRootPackage: Boolean val reportUndocumented: Boolean val skipEmptyPackages: Boolean val skipDeprecated: Boolean val jdkVersion: Int val sourceLinks: List val perPackageOptions: List val externalDocumentationLinks: List val languageVersion: String? val apiVersion: String? val noStdlibLink: Boolean val noJdkLink: Boolean val suppressedFiles: List val collectInheritedExtensionsFromLibraries: Boolean val analysisPlatform: Platform val targets: List } interface SourceRoot { val path: String } interface SourceLinkDefinition { val path: String val url: String val lineSuffix: String? } interface PackageOptions { val prefix: String val includeNonPublic: Boolean val reportUndocumented: Boolean val skipDeprecated: Boolean val suppress: Boolean } interface ExternalDocumentationLink { @CustomSerializer(UrlSerializer::class) val url: URL @CustomSerializer(UrlSerializer::class) val packageListUrl: URL open class Builder(open var url: URL? = null, open var packageListUrl: URL? = null) { constructor(root: String, packageList: String? = null) : this(URL(root), packageList?.let { URL(it) }) fun build(): DokkaConfiguration.ExternalDocumentationLink = if (packageListUrl != null && url != null) ExternalDocumentationLinkImpl(url!!, packageListUrl!!) else if (url != null) ExternalDocumentationLinkImpl(url!!, URL(url!!, "package-list")) else throw IllegalArgumentException("url or url && packageListUrl must not be null for external documentation link") } } } data class SerializeOnlyDokkaConfiguration( override val outputDir: String, override val format: String, override val generateIndexPages: Boolean, override val cacheRoot: String?, override val impliedPlatforms: List, override val passesConfigurations: List ) : DokkaConfiguration data class ExternalDocumentationLinkImpl(@CustomSerializer(UrlSerializer::class) override val url: URL, @CustomSerializer(UrlSerializer::class) override val packageListUrl: URL) : Serializable, DokkaConfiguration.ExternalDocumentationLink