aboutsummaryrefslogtreecommitdiff
path: root/plugins/base
diff options
context:
space:
mode:
authorKamil Doległo <kamilok1965@interia.pl>2020-03-13 13:18:12 +0100
committerPaweł Marks <Kordyjan@users.noreply.github.com>2020-03-17 16:03:36 +0100
commita01554561ca8d18a1cf3c94df47e4b38fae1c538 (patch)
tree38ea3044b122b44f57bad45ae98b24679e1316a8 /plugins/base
parent7cfdd8a512adb6b8589328610efb5bd56c3c0dd7 (diff)
downloaddokka-a01554561ca8d18a1cf3c94df47e4b38fae1c538.tar.gz
dokka-a01554561ca8d18a1cf3c94df47e4b38fae1c538.tar.bz2
dokka-a01554561ca8d18a1cf3c94df47e4b38fae1c538.zip
Add annotation parsing in Java sources
Diffstat (limited to 'plugins/base')
-rw-r--r--plugins/base/src/main/kotlin/translators/psi/DefaultPsiToDocumentableTranslator.kt49
1 files changed, 38 insertions, 11 deletions
diff --git a/plugins/base/src/main/kotlin/translators/psi/DefaultPsiToDocumentableTranslator.kt b/plugins/base/src/main/kotlin/translators/psi/DefaultPsiToDocumentableTranslator.kt
index c5c72a65..0e1e0a18 100644
--- a/plugins/base/src/main/kotlin/translators/psi/DefaultPsiToDocumentableTranslator.kt
+++ b/plugins/base/src/main/kotlin/translators/psi/DefaultPsiToDocumentableTranslator.kt
@@ -59,7 +59,7 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
class DokkaPsiParser(
private val platformData: PlatformData,
- logger: DokkaLogger
+ private val logger: DokkaLogger
) {
private val javadocParser: JavaDocumentationParser = JavadocParser(logger)
@@ -144,7 +144,8 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
visibility,
null,
constructors.map { parseFunction(it, dri, true) },
- listOf(platformData)
+ listOf(platformData),
+ PropertyContainer.empty<Annotation>() + annotations.toList().toExtra()
)
isEnum -> DEnum(
dri,
@@ -157,7 +158,8 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
emptyList(),
emptyList(),
emptyList(),
- listOf(platformData)
+ listOf(platformData),
+ PropertyContainer.empty<EnumEntry>() + entry.annotations.toList().toExtra()
)
},
documentation,
@@ -169,7 +171,8 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
null,
constructors.map { parseFunction(it, dri, true) },
ancestors,
- listOf(platformData)
+ listOf(platformData),
+ PropertyContainer.empty<Enum>() + annotations.toList().toExtra()
)
isInterface -> DInterface(
dri,
@@ -183,7 +186,8 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
null,
mapTypeParameters(dri),
ancestors,
- listOf(platformData)
+ listOf(platformData),
+ PropertyContainer.empty<Interface>() + annotations.toList().toExtra()
)
else -> DClass(
dri,
@@ -199,7 +203,8 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
ancestors,
documentation,
getModifier(),
- listOf(platformData)
+ listOf(platformData),
+ PropertyContainer.empty<Class>() + annotations.toList().toExtra()
)
}
}
@@ -239,9 +244,9 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
null,
psi.getModifier(),
listOf(platformData),
- PropertyContainer.empty<DFunction>() + InheritedFunction(
- isInherited
- )
+ PropertyContainer.empty<DFunction>()
+ + InheritedFunction(isInherited)
+ + psi.annotations.toList().toExtra()
)
}
@@ -254,7 +259,10 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
val arguments = type.parameters.map { getProjection(it) }
TypeConstructor(DRI.from(resolved), arguments)
}
- is PsiArrayType -> TypeConstructor(DRI("kotlin", "Array"), listOf(getProjection(type.componentType)))
+ is PsiArrayType -> TypeConstructor(
+ DRI("kotlin", "Array"),
+ listOf(getProjection(type.componentType))
+ )
is PsiPrimitiveType -> PrimitiveJavaType(type.name)
else -> throw IllegalStateException("${type.presentableText} is not supported by PSI parser")
}
@@ -342,8 +350,27 @@ object DefaultPsiToDocumentableTranslator : PsiToDocumentableTranslator {
accessors.firstOrNull { it.hasParameters() }?.let { parseFunction(it, parent) },
accessors.firstOrNull { it.returnType == psi.type }?.let { parseFunction(it, parent) },
psi.getModifier(),
- listOf(platformData)
+ listOf(platformData),
+ PropertyContainer.empty<Property>() + psi.annotations.toList().toExtra()
)
}
+
+ private fun Collection<PsiAnnotation>.toExtra() = mapNotNull { annotation ->
+ val fqname = annotation.qualifiedName ?: run {
+ logger.error("No fqName for $annotation!")
+ return@mapNotNull null
+ }
+
+ Annotations.Annotation(
+ DRI(fqname.substringBeforeLast("."), fqname.substringAfterLast(".")), // TODO: create a proper DRI
+ annotation.attributes.mapNotNull {
+ if (it is PsiNameValuePair) {
+ it.attributeName to it.value.toString()
+ } else {
+ it.attributeName to ""
+ }
+ }.toMap()
+ )
+ }.let(::Annotations)
}
}