aboutsummaryrefslogtreecommitdiff
path: root/src/Java/JavaPsiDocumentationBuilder.kt
diff options
context:
space:
mode:
authorDmitry Jemerov <yole@jetbrains.com>2015-11-03 20:21:52 +0100
committerDmitry Jemerov <yole@jetbrains.com>2015-11-03 20:21:52 +0100
commitfb25c1eaf41ae314d19d6cda55446a2ab6b63715 (patch)
tree99cb6e86eb45a7ea4a3f0eeb2f35f200c3117270 /src/Java/JavaPsiDocumentationBuilder.kt
parentaa9395aa97a9d738125e21d5ed235b350d637a24 (diff)
downloaddokka-fb25c1eaf41ae314d19d6cda55446a2ab6b63715.tar.gz
dokka-fb25c1eaf41ae314d19d6cda55446a2ab6b63715.tar.bz2
dokka-fb25c1eaf41ae314d19d6cda55446a2ab6b63715.zip
reduce the number of Kotlinisms in documentation model generated from Java code
Diffstat (limited to 'src/Java/JavaPsiDocumentationBuilder.kt')
-rw-r--r--src/Java/JavaPsiDocumentationBuilder.kt27
1 files changed, 8 insertions, 19 deletions
diff --git a/src/Java/JavaPsiDocumentationBuilder.kt b/src/Java/JavaPsiDocumentationBuilder.kt
index a5ee891e..bdc6a368 100644
--- a/src/Java/JavaPsiDocumentationBuilder.kt
+++ b/src/Java/JavaPsiDocumentationBuilder.kt
@@ -186,14 +186,10 @@ private fun PsiType.typeSignature(): String = when(this) {
}
private fun mapTypeName(psiType: PsiType): String = when (psiType) {
- PsiType.VOID -> "Unit"
- is PsiPrimitiveType -> psiType.canonicalText.capitalize()
- is PsiClassType -> {
- val psiClass = psiType.resolve()
- if (psiClass?.qualifiedName == "java.lang.Object") "Any" else psiType.className
- }
+ is PsiPrimitiveType -> psiType.canonicalText
+ is PsiClassType -> psiType.className
is PsiEllipsisType -> mapTypeName(psiType.componentType)
- is PsiArrayType -> "Array"
+ is PsiArrayType -> mapTypeName(psiType.componentType) + "[]"
else -> psiType.canonicalText
}
@@ -236,6 +232,7 @@ class JavaPsiDocumentationBuilder(private val options: DocumentationOptions,
refGraph.link(qualifiedName, node, kind)
}
}
+
fun DocumentationNode(element: PsiNamedElement,
kind: Kind,
name: String = element.name ?: "<anonymous>"): DocumentationNode {
@@ -326,18 +323,15 @@ class JavaPsiDocumentationBuilder(private val options: DocumentationOptions,
fun PsiField.build(): DocumentationNode {
val node = DocumentationNode(this, nodeKind())
- if (!hasModifierProperty(PsiModifier.FINAL)) {
- node.appendTextNode("var", Kind.Modifier)
- }
node.appendType(type)
+ node.appendModifiers(this)
register(this, node)
return node
}
private fun PsiField.nodeKind(): Kind = when {
this is PsiEnumConstant -> Kind.EnumItem
- hasModifierProperty(PsiModifier.STATIC) -> Kind.CompanionObjectProperty
- else -> Kind.Property
+ else -> Kind.Field
}
fun PsiMethod.build(): DocumentationNode {
@@ -355,7 +349,6 @@ class JavaPsiDocumentationBuilder(private val options: DocumentationOptions,
private fun PsiMethod.nodeKind(): Kind = when {
isConstructor -> Kind.Constructor
- hasModifierProperty(PsiModifier.STATIC) -> Kind.CompanionObjectFunction
else -> Kind.Function
}
@@ -363,7 +356,7 @@ class JavaPsiDocumentationBuilder(private val options: DocumentationOptions,
val node = DocumentationNode(this, Kind.Parameter)
node.appendType(type)
if (type is PsiEllipsisType) {
- node.appendTextNode("vararg", Kind.Annotation, DocumentationReference.Kind.Annotation)
+ node.appendTextNode("vararg", Kind.Modifier, DocumentationReference.Kind.Detail)
}
return node
}
@@ -379,14 +372,10 @@ class JavaPsiDocumentationBuilder(private val options: DocumentationOptions,
val modifierList = element.modifierList ?: return
PsiModifier.MODIFIERS.forEach {
- if (it != "static" && modifierList.hasExplicitModifier(it)) {
+ if (modifierList.hasExplicitModifier(it)) {
appendTextNode(it, Kind.Modifier)
}
}
- if ((element is PsiClass || (element is PsiMethod && !element.isConstructor)) &&
- !element.hasModifierProperty(PsiModifier.FINAL)) {
- appendTextNode("open", Kind.Modifier)
- }
}
fun DocumentationNode.appendType(psiType: PsiType?, kind: DocumentationNode.Kind = DocumentationNode.Kind.Type) {