From 6584b8d2a834ec55bfbba13dd069e469b19e5f20 Mon Sep 17 00:00:00 2001
From: anmeng10101 <33647870+anmeng10101@users.noreply.github.com>
Date: Fri, 15 May 2020 15:28:48 +0800
Subject: [PATCH 1/4] exclude private and package-private classes during
documentation (#36)
---
.../com/microsoft/build/YmlFilesBuilder.java | 2 +-
.../java/com/microsoft/util/ElementUtil.java | 3 +++
.../samples/subpackage/CustomException.java | 4 ++++
.../samples/subpackage/InternalException.java | 8 ++++++++
.../com/microsoft/util/ElementUtilTest.java | 20 ++++++++++++++-----
5 files changed, 31 insertions(+), 6 deletions(-)
create mode 100644 src/test/java/com/microsoft/samples/subpackage/InternalException.java
diff --git a/src/main/java/com/microsoft/build/YmlFilesBuilder.java b/src/main/java/com/microsoft/build/YmlFilesBuilder.java
index 2a5c50c..d247d6a 100644
--- a/src/main/java/com/microsoft/build/YmlFilesBuilder.java
+++ b/src/main/java/com/microsoft/build/YmlFilesBuilder.java
@@ -286,7 +286,7 @@ void addSuperclassAndInterfacesReferences(TypeElement classElement, MetadataFile
void addInnerClassesReferences(TypeElement classElement, MetadataFile classMetadataFile) {
classMetadataFile.getReferences().addAll(
- ElementFilter.typesIn(classElement.getEnclosedElements()).stream()
+ ElementFilter.typesIn(elementUtil.extractSortedElements(classElement)).stream()
.map(this::buildClassReference)
.collect(Collectors.toList()));
}
diff --git a/src/main/java/com/microsoft/util/ElementUtil.java b/src/main/java/com/microsoft/util/ElementUtil.java
index 0f850ea..85f9b24 100644
--- a/src/main/java/com/microsoft/util/ElementUtil.java
+++ b/src/main/java/com/microsoft/util/ElementUtil.java
@@ -28,7 +28,10 @@ public ElementUtil(String[] excludePackages, String[] excludeClasses) {
public List extractSortedElements(Element element) {
// Need to apply sorting, because order of result items for Element.getEnclosedElements() depend on JDK implementation
+ // By default, exclude private and package-private items
+ // todo allow pass parameter for filter items by access modifiers
return ElementFilter.typesIn(element.getEnclosedElements()).stream()
+ .filter(o -> !isPrivateOrPackagePrivate(o))
.filter(o -> !matchAnyPattern(excludeClasses, String.valueOf(o.getQualifiedName())))
.sorted((o1, o2) ->
StringUtils.compare(String.valueOf(o1.getSimpleName()), String.valueOf(o2.getSimpleName()))
diff --git a/src/test/java/com/microsoft/samples/subpackage/CustomException.java b/src/test/java/com/microsoft/samples/subpackage/CustomException.java
index 4f7d02a..8717af6 100644
--- a/src/test/java/com/microsoft/samples/subpackage/CustomException.java
+++ b/src/test/java/com/microsoft/samples/subpackage/CustomException.java
@@ -14,4 +14,8 @@ public CustomException(String message) {
public void makeSomething() throws CustomException {
throw new CustomException("It happened!");
}
+
+ private class PrivateException {
+ private String message;
+ }
}
diff --git a/src/test/java/com/microsoft/samples/subpackage/InternalException.java b/src/test/java/com/microsoft/samples/subpackage/InternalException.java
new file mode 100644
index 0000000..c868a4c
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/subpackage/InternalException.java
@@ -0,0 +1,8 @@
+package com.microsoft.samples.subpackage;
+
+class InternalException extends Exception {
+
+ public InternalException(String message) {
+ super(message);
+ }
+}
diff --git a/src/test/java/com/microsoft/util/ElementUtilTest.java b/src/test/java/com/microsoft/util/ElementUtilTest.java
index 4d3780c..73138f5 100644
--- a/src/test/java/com/microsoft/util/ElementUtilTest.java
+++ b/src/test/java/com/microsoft/util/ElementUtilTest.java
@@ -55,13 +55,23 @@ public void extractPackageElements() {
public void extractSortedElements() {
Element element = elements.getPackageElement("com.microsoft.samples.subpackage");
- List result = elementUtil.extractSortedElements(element)
+ List allElements = element.getEnclosedElements()
+ .stream().map(String::valueOf).collect(Collectors.toList());
+
+ // Ensure items to exclude exist.
+ assertThat("Wrong enclosed elements number", allElements.size(), is(6));
+ assertTrue("Unexpected package private class", allElements.contains("com.microsoft.samples.subpackage.InternalException"));
+ assertTrue("Unexpected to-exclude class", allElements.contains("com.microsoft.samples.subpackage.SomeExcludedClass"));
+
+
+ List extractedElements = elementUtil.extractSortedElements(element)
.stream().map(String::valueOf).collect(Collectors.toList());
- assertThat("Wrong result list size", result.size(), is(4));
- assertThat("Unexpected first item", result.get(0), is("com.microsoft.samples.subpackage.CustomException"));
- assertThat("Unexpected second item", result.get(1), is("com.microsoft.samples.subpackage.Display"));
- assertThat("Unexpected third item", result.get(2), is("com.microsoft.samples.subpackage.Person"));
+ // Verify filtered and sorted result
+ assertThat("Wrong result list size", extractedElements.size(), is(4));
+ assertThat("Unexpected first item in the result list after invoke method extractSortedElements()", extractedElements.get(0), is("com.microsoft.samples.subpackage.CustomException"));
+ assertThat("Unexpected second item in the result list after invoke method extractSortedElements()", extractedElements.get(1), is("com.microsoft.samples.subpackage.Display"));
+ assertThat("Unexpected third item in the result list after invoke method extractSortedElements()", extractedElements.get(2), is("com.microsoft.samples.subpackage.Person"));
}
@Test
From 1175eb234e1e9f47064e75cda1b49e6b448e915e Mon Sep 17 00:00:00 2001
From: anmeng10101 <33647870+anmeng10101@users.noreply.github.com>
Date: Mon, 18 May 2020 15:15:11 +0800
Subject: [PATCH 2/4] move functions for single element to a separate utility
class (#37)
---
.../com/microsoft/build/YmlFilesBuilder.java | 7 +-
.../com/microsoft/lookup/ClassLookup.java | 4 +-
.../java/com/microsoft/util/ElementUtil.java | 23 +---
src/main/java/com/microsoft/util/Utils.java | 27 +++++
.../java/com/microsoft/samples/SuperHero.java | 14 ++-
.../com/microsoft/util/ElementUtilTest.java | 28 +----
.../java/com/microsoft/util/UtilsTest.java | 100 ++++++++++++++++++
.../com.microsoft.samples.SuperHero.yml | 4 +-
8 files changed, 147 insertions(+), 60 deletions(-)
create mode 100644 src/main/java/com/microsoft/util/Utils.java
create mode 100644 src/test/java/com/microsoft/util/UtilsTest.java
diff --git a/src/main/java/com/microsoft/build/YmlFilesBuilder.java b/src/main/java/com/microsoft/build/YmlFilesBuilder.java
index d247d6a..ede7a95 100644
--- a/src/main/java/com/microsoft/build/YmlFilesBuilder.java
+++ b/src/main/java/com/microsoft/build/YmlFilesBuilder.java
@@ -7,6 +7,7 @@
import com.microsoft.model.*;
import com.microsoft.util.ElementUtil;
import com.microsoft.util.FileUtil;
+import com.microsoft.util.Utils;
import com.microsoft.util.YamlUtil;
import jdk.javadoc.doclet.DocletEnvironment;
import org.apache.commons.lang3.RegExUtils;
@@ -166,7 +167,7 @@ void addChildren(TypeElement classElement, List children) {
List extends Element> filterPrivateElements(List extends Element> elements) {
return elements.stream()
- .filter(element -> !ElementUtil.isPrivateOrPackagePrivate(element)).collect(Collectors.toList());
+ .filter(element -> !Utils.isPrivateOrPackagePrivate(element)).collect(Collectors.toList());
}
void collect(TypeElement classElement, List children,
@@ -193,7 +194,7 @@ void addConstructorsInfo(TypeElement classElement, MetadataFile classMetadataFil
void addMethodsInfo(TypeElement classElement, MetadataFile classMetadataFile) {
ElementFilter.methodsIn(classElement.getEnclosedElements()).stream()
- .filter(methodElement -> !ElementUtil.isPrivateOrPackagePrivate(methodElement))
+ .filter(methodElement -> !Utils.isPrivateOrPackagePrivate(methodElement))
.forEach(methodElement -> {
MetadataFileItem methodItem = buildMetadataFileItem(methodElement);
methodItem.setOverload(classItemsLookup.extractOverload(methodElement));
@@ -212,7 +213,7 @@ void addMethodsInfo(TypeElement classElement, MetadataFile classMetadataFile) {
void addFieldsInfo(TypeElement classElement, MetadataFile classMetadataFile) {
ElementFilter.fieldsIn(classElement.getEnclosedElements()).stream()
- .filter(fieldElement -> !ElementUtil.isPrivateOrPackagePrivate(fieldElement))
+ .filter(fieldElement -> !Utils.isPrivateOrPackagePrivate(fieldElement))
.forEach(fieldElement -> {
MetadataFileItem fieldItem = buildMetadataFileItem(fieldElement);
fieldItem.setContent(classItemsLookup.extractFieldContent(fieldElement));
diff --git a/src/main/java/com/microsoft/lookup/ClassLookup.java b/src/main/java/com/microsoft/lookup/ClassLookup.java
index e875836..f5c67cb 100644
--- a/src/main/java/com/microsoft/lookup/ClassLookup.java
+++ b/src/main/java/com/microsoft/lookup/ClassLookup.java
@@ -3,7 +3,7 @@
import com.microsoft.lookup.model.ExtendedMetadataFileItem;
import com.microsoft.model.MetadataFileItem;
import com.microsoft.model.TypeParameter;
-import com.microsoft.util.ElementUtil;
+import com.microsoft.util.Utils;
import jdk.javadoc.doclet.DocletEnvironment;
import org.apache.commons.collections4.CollectionUtils;
import org.apache.commons.lang3.StringUtils;
@@ -146,7 +146,7 @@ void appendInheritedMethods(TypeElement element, List
.orElse(0);
for (Element m : members) {
- if (m.getKind() == ElementKind.METHOD && !ElementUtil.isPrivateOrPackagePrivate(m)) {
+ if (m.getKind() == ElementKind.METHOD && !Utils.isPrivateOrPackagePrivate(m)) {
String uid = element.getQualifiedName().toString().concat(".") + String.valueOf(m);
ExtendedMetadataFileItem item = new ExtendedMetadataFileItem(uid);
diff --git a/src/main/java/com/microsoft/util/ElementUtil.java b/src/main/java/com/microsoft/util/ElementUtil.java
index 85f9b24..fa83605 100644
--- a/src/main/java/com/microsoft/util/ElementUtil.java
+++ b/src/main/java/com/microsoft/util/ElementUtil.java
@@ -3,7 +3,6 @@
import org.apache.commons.lang3.StringUtils;
import javax.lang.model.element.Element;
-import javax.lang.model.element.Modifier;
import javax.lang.model.element.PackageElement;
import javax.lang.model.element.TypeElement;
import javax.lang.model.util.ElementFilter;
@@ -31,7 +30,7 @@ public List extractSortedElements(Element element) {
// By default, exclude private and package-private items
// todo allow pass parameter for filter items by access modifiers
return ElementFilter.typesIn(element.getEnclosedElements()).stream()
- .filter(o -> !isPrivateOrPackagePrivate(o))
+ .filter(o -> !Utils.isPrivateOrPackagePrivate(o))
.filter(o -> !matchAnyPattern(excludeClasses, String.valueOf(o.getQualifiedName())))
.sorted((o1, o2) ->
StringUtils.compare(String.valueOf(o1.getSimpleName()), String.valueOf(o2.getSimpleName()))
@@ -54,24 +53,4 @@ boolean matchAnyPattern(Set patterns, String stringToCheck) {
}
return false;
}
-
- public static boolean isPackagePrivate(Element e) {
- return !(isPublic(e) || isPrivate(e) || isProtected(e));
- }
-
- public static boolean isPrivate(Element e) {
- return e.getModifiers().contains(Modifier.PRIVATE);
- }
-
- public static boolean isProtected(Element e) {
- return e.getModifiers().contains(Modifier.PROTECTED);
- }
-
- public static boolean isPublic(Element e) {
- return e.getModifiers().contains(Modifier.PUBLIC);
- }
-
- public static boolean isPrivateOrPackagePrivate(Element e) {
- return isPrivate(e) || isPackagePrivate(e);
- }
}
diff --git a/src/main/java/com/microsoft/util/Utils.java b/src/main/java/com/microsoft/util/Utils.java
new file mode 100644
index 0000000..a18edff
--- /dev/null
+++ b/src/main/java/com/microsoft/util/Utils.java
@@ -0,0 +1,27 @@
+package com.microsoft.util;
+
+import javax.lang.model.element.Element;
+import javax.lang.model.element.Modifier;
+
+public class Utils {
+
+ public static boolean isPackagePrivate(Element e) {
+ return !(isPublic(e) || isPrivate(e) || isProtected(e));
+ }
+
+ public static boolean isPrivate(Element e) {
+ return e.getModifiers().contains(Modifier.PRIVATE);
+ }
+
+ public static boolean isProtected(Element e) {
+ return e.getModifiers().contains(Modifier.PROTECTED);
+ }
+
+ public static boolean isPublic(Element e) {
+ return e.getModifiers().contains(Modifier.PUBLIC);
+ }
+
+ public static boolean isPrivateOrPackagePrivate(Element e) {
+ return isPrivate(e) || isPackagePrivate(e);
+ }
+}
diff --git a/src/test/java/com/microsoft/samples/SuperHero.java b/src/test/java/com/microsoft/samples/SuperHero.java
index 25d2da2..54276e6 100644
--- a/src/test/java/com/microsoft/samples/SuperHero.java
+++ b/src/test/java/com/microsoft/samples/SuperHero.java
@@ -39,7 +39,7 @@ public SuperHero(String heroName, String uniquePower, int health, int defense) {
*
*
* @param incomingDamage the amount of incoming damage for {@link SuperHero}
- * @param damageType type of damage with similar word damageTypeLong, sure
+ * @param damageType type of damage with similar word damageTypeLong, sure
* @return the amount of health hero has after attack
* @throws IllegalArgumentException when incomingDamage is negative and thanks for {@link Exception}
* @version 1.2
@@ -84,11 +84,11 @@ public void setUniquePower(String uniquePower) {
this.uniquePower = uniquePower;
}
- public int getHealth() {
+ protected int getHealth() {
return health;
}
- public void setHealth(int health) {
+ protected void setHealth(int health) {
this.health = health;
}
@@ -100,7 +100,11 @@ public void setDefense(int defense) {
this.defense = defense;
}
- private void somePrivateMethod() {}
+ private void setHobby(String hobby) {
+ this.hobby = hobby;
+ }
- void somePackagePrivateMethod() {}
+ String getHobby() {
+ return hobby;
+ }
}
diff --git a/src/test/java/com/microsoft/util/ElementUtilTest.java b/src/test/java/com/microsoft/util/ElementUtilTest.java
index 73138f5..cf2b871 100644
--- a/src/test/java/com/microsoft/util/ElementUtilTest.java
+++ b/src/test/java/com/microsoft/util/ElementUtilTest.java
@@ -60,8 +60,8 @@ public void extractSortedElements() {
// Ensure items to exclude exist.
assertThat("Wrong enclosed elements number", allElements.size(), is(6));
- assertTrue("Unexpected package private class", allElements.contains("com.microsoft.samples.subpackage.InternalException"));
- assertTrue("Unexpected to-exclude class", allElements.contains("com.microsoft.samples.subpackage.SomeExcludedClass"));
+ assertThat("Unexpected package private class", allElements.contains("com.microsoft.samples.subpackage.InternalException"), is(true));
+ assertThat("Unexpected to-exclude class", allElements.contains("com.microsoft.samples.subpackage.SomeExcludedClass"), is(true));
List extractedElements = elementUtil.extractSortedElements(element)
@@ -83,28 +83,4 @@ public void matchAnyPattern() {
assertFalse(elementUtil.matchAnyPattern(patterns, "EngineFive"));
assertFalse(elementUtil.matchAnyPattern(patterns, "com.ms.Awesome"));
}
-
- @Test
- public void isPackagePrivate() {
- Element element = elements.getTypeElement("com.microsoft.samples.SuperHero");
-
- List result = element.getEnclosedElements()
- .stream().filter(e -> ElementUtil.isPackagePrivate(e)).collect(Collectors.toList());
-
- assertThat("Wrong result list size", result.size(), is(2));
- assertThat("Unexpected package private field", String.valueOf(result.get(0)), is("hobby"));
- assertThat("Unexpected package private method", String.valueOf(result.get(1)), is("somePackagePrivateMethod()"));
- }
-
- @Test
- public void isPrivateOrPackagePrivate() {
- Element element = elements.getTypeElement("com.microsoft.samples.SuperHero");
-
- List result = element.getEnclosedElements()
- .stream().filter(e -> ElementUtil.isPrivateOrPackagePrivate(e)).collect(Collectors.toList());
-
- assertThat("Wrong result list size", result.size(), is(7));
- assertThat("Unexpected private method", String.valueOf(result.get(5)), is("somePrivateMethod()"));
- assertThat("Unexpected package private method", String.valueOf(result.get(6)), is("somePackagePrivateMethod()"));
- }
}
diff --git a/src/test/java/com/microsoft/util/UtilsTest.java b/src/test/java/com/microsoft/util/UtilsTest.java
new file mode 100644
index 0000000..679dbd8
--- /dev/null
+++ b/src/test/java/com/microsoft/util/UtilsTest.java
@@ -0,0 +1,100 @@
+package com.microsoft.util;
+
+import java.util.List;
+import java.util.stream.Collectors;
+
+import javax.lang.model.element.Element;
+import javax.lang.model.element.ElementKind;
+import javax.lang.model.util.Elements;
+
+import org.junit.*;
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+import org.mockito.junit.MockitoJUnitRunner;
+
+import com.google.testing.compile.CompilationRule;
+
+import static org.hamcrest.CoreMatchers.is;
+import static org.junit.Assert.*;
+
+@RunWith(MockitoJUnitRunner.class)
+public class UtilsTest {
+
+ @Rule
+ public CompilationRule rule = new CompilationRule();
+ private Elements elements;
+ private List allElements;
+
+ @Before
+ public void setup() {
+ elements = rule.getElements();
+ Element element = elements.getTypeElement("com.microsoft.samples.SuperHero");
+ allElements = element.getEnclosedElements().stream().collect(Collectors.toList());
+ }
+
+ // Test isPackagePrivate() method
+ @Test
+ public void isPackagePrivate_True_PackagePrivateMethod() {
+ Element method = getElementByKindAndName(allElements, ElementKind.METHOD, "getHobby()");
+ assertThat(Utils.isPackagePrivate(method), is(true));
+ }
+
+ @Test
+ public void isPackagePrivate_True_PackagePrivateField() {
+ Element field = getElementByKindAndName(allElements, ElementKind.FIELD, "hobby");
+ assertThat(Utils.isPackagePrivate(field), is(true));
+ }
+
+ // Test isPrivate() method
+ @Test
+ public void isPrivate_True_PrivateMethod() {
+ Element method = getElementByKindAndName(allElements, ElementKind.METHOD, "setHobby(java.lang.String)");
+ assertThat(Utils.isPrivate(method), is(true));
+ }
+
+ @Test
+ public void isPrivate_True_PrivateField() {
+ Element field = getElementByKindAndName(allElements, ElementKind.FIELD, "uniquePower");
+ assertThat(Utils.isPrivate(field), is(true));
+ }
+
+ // Test isPrivateOrPackagePrivate() method
+ @Test
+ public void isPrivateOrPackagePrivate_True_PackagePrivateMethod() {
+ Element method = getElementByKindAndName(allElements, ElementKind.METHOD, "getHobby()");
+ assertThat(Utils.isPrivateOrPackagePrivate(method), is(true));
+ }
+
+ @Test
+ public void isPrivateOrPackagePrivate_True_PrivateFiled() {
+ Element field = getElementByKindAndName(allElements, ElementKind.FIELD, "uniquePower");
+ assertThat(Utils.isPrivateOrPackagePrivate(field), is(true));
+ }
+
+ @Test
+ public void isPrivateOrPackagePrivate_False_PublicMethod() {
+ Element method = getElementByKindAndName(allElements, ElementKind.METHOD, "getUniquePower()");
+ assertThat(Utils.isPrivateOrPackagePrivate(method), is(false));
+ }
+
+ @Test
+ public void isPrivateOrPackagePrivate_False_PublicField() {
+ Element field = getElementByKindAndName(allElements, ElementKind.FIELD, "SOME_PUBLIC_STRING");
+ assertThat(Utils.isPrivateOrPackagePrivate(field), is(false));
+ }
+
+ @Test
+ public void isPrivateOrPackagePrivate_False_ProtectedMethod() {
+ Element method = getElementByKindAndName(allElements, ElementKind.METHOD, "getHealth()");
+ assertThat(Utils.isPrivateOrPackagePrivate(method), is(false));
+ }
+
+ private Element getElementByKindAndName(List extends Element> elements, ElementKind elementKind, String name) {
+ return elements.stream()
+ .filter(e -> e.toString().equals(name))
+ .filter(e -> e.getKind() == elementKind)
+ .findFirst().orElse(null);
+ }
+}
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml
index b63bd8b..9cab56c 100644
--- a/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml
@@ -128,7 +128,7 @@ items:
type: "Method"
package: "com.microsoft.samples"
syntax:
- content: "public int getHealth()"
+ content: "protected int getHealth()"
return:
type: "int"
- uid: "com.microsoft.samples.SuperHero.getHeroName()"
@@ -206,7 +206,7 @@ items:
type: "Method"
package: "com.microsoft.samples"
syntax:
- content: "public void setHealth(int health)"
+ content: "protected void setHealth(int health)"
parameters:
- id: "health"
type: "int"
From 6b05484f81448865adf3a074967f3aaa219510ed Mon Sep 17 00:00:00 2001
From: anmeng10101 <33647870+anmeng10101@users.noreply.github.com>
Date: Mon, 1 Jun 2020 10:34:44 +0800
Subject: [PATCH 3/4] add step to search if there is any item in super class
being overridden by given method, and add yaml. (#38)
---
.../com/microsoft/build/YmlFilesBuilder.java | 3 +-
.../java/com/microsoft/lookup/BaseLookup.java | 42 ++--
.../microsoft/lookup/ClassItemsLookup.java | 55 ++++--
.../com/microsoft/model/MetadataFileItem.java | 11 +-
src/main/java/com/microsoft/util/Utils.java | 185 +++++++++++++++++-
...oft.samples.BasePartnerComponentString.yml | 1 +
.../com.microsoft.samples.SuperHero.yml | 1 +
7 files changed, 257 insertions(+), 41 deletions(-)
diff --git a/src/main/java/com/microsoft/build/YmlFilesBuilder.java b/src/main/java/com/microsoft/build/YmlFilesBuilder.java
index ede7a95..06ffa06 100644
--- a/src/main/java/com/microsoft/build/YmlFilesBuilder.java
+++ b/src/main/java/com/microsoft/build/YmlFilesBuilder.java
@@ -202,6 +202,7 @@ void addMethodsInfo(TypeElement classElement, MetadataFile classMetadataFile) {
methodItem.setExceptions(classItemsLookup.extractExceptions(methodElement));
methodItem.setParameters(classItemsLookup.extractParameters(methodElement));
methodItem.setReturn(classItemsLookup.extractReturn(methodElement));
+ methodItem.setOverridden(classItemsLookup.extractOverridden(methodElement));
classMetadataFile.getItems().add(methodItem);
addExceptionReferences(methodItem, classMetadataFile);
@@ -489,7 +490,7 @@ String resolveUidFromReference(String linkContent, LookupContext lookupContext)
return uid;
}
- String resolveUidByLookup(String signature, LookupContext lookupContext){
+ String resolveUidByLookup(String signature, LookupContext lookupContext) {
if (StringUtils.isBlank(signature) || lookupContext == null) {
return "";
}
diff --git a/src/main/java/com/microsoft/lookup/BaseLookup.java b/src/main/java/com/microsoft/lookup/BaseLookup.java
index 5b846af..68b6fdd 100644
--- a/src/main/java/com/microsoft/lookup/BaseLookup.java
+++ b/src/main/java/com/microsoft/lookup/BaseLookup.java
@@ -6,6 +6,7 @@
import com.microsoft.model.MethodParameter;
import com.microsoft.model.Return;
import com.microsoft.model.TypeParameter;
+
import com.sun.source.doctree.DocCommentTree;
import com.sun.source.doctree.DocTree;
import com.sun.source.doctree.LinkTree;
@@ -14,9 +15,12 @@
import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.Stream;
+
import javax.lang.model.element.Element;
import javax.lang.model.element.ElementKind;
+
import jdk.javadoc.doclet.DocletEnvironment;
+
import org.apache.commons.lang3.RegExUtils;
import org.apache.commons.lang3.StringUtils;
@@ -152,6 +156,10 @@ public Set extractReferences(T key) {
return resolve(key).getReferences();
}
+ public String extractOverridden(T key) {
+ return resolve(key).getOverridden();
+ }
+
protected String determineType(T element) {
return elementKindLookup.get(element.getKind());
}
@@ -162,9 +170,9 @@ protected String determinePackageName(T element) {
protected String determineComment(T element) {
return getDocCommentTree(element)
- .map(DocCommentTree::getFullBody)
- .map(this::replaceLinksAndCodes)
- .orElse(null);
+ .map(DocCommentTree::getFullBody)
+ .map(this::replaceLinksAndCodes)
+ .orElse(null);
}
/**
@@ -175,19 +183,19 @@ protected String determineComment(T element) {
*/
String replaceLinksAndCodes(List extends DocTree> items) {
return items.stream().map(
- bodyItem -> {
- switch (bodyItem.getKind()) {
- case LINK:
- case LINK_PLAIN:
- return buildXrefTag((LinkTree) bodyItem);
- case CODE:
- return buildCodeTag((LiteralTree) bodyItem);
- case LITERAL:
- return expandLiteralBody((LiteralTree) bodyItem);
- default:
- return String.valueOf(bodyItem);
+ bodyItem -> {
+ switch (bodyItem.getKind()) {
+ case LINK:
+ case LINK_PLAIN:
+ return buildXrefTag((LinkTree) bodyItem);
+ case CODE:
+ return buildCodeTag((LiteralTree) bodyItem);
+ case LITERAL:
+ return expandLiteralBody((LiteralTree) bodyItem);
+ default:
+ return String.valueOf(bodyItem);
+ }
}
- }
).collect(Collectors.joining());
}
@@ -223,7 +231,7 @@ public String makeTypeShort(String value) {
return value;
}
return Stream.of(StringUtils.split(value, "<"))
- .map(s -> RegExUtils.removeAll(s, "\\b[a-z0-9_.]+\\."))
- .collect(Collectors.joining("<"));
+ .map(s -> RegExUtils.removeAll(s, "\\b[a-z0-9_.]+\\."))
+ .collect(Collectors.joining("<"));
}
}
diff --git a/src/main/java/com/microsoft/lookup/ClassItemsLookup.java b/src/main/java/com/microsoft/lookup/ClassItemsLookup.java
index 9f54d85..1b23454 100644
--- a/src/main/java/com/microsoft/lookup/ClassItemsLookup.java
+++ b/src/main/java/com/microsoft/lookup/ClassItemsLookup.java
@@ -4,23 +4,25 @@
import com.microsoft.model.ExceptionItem;
import com.microsoft.model.MethodParameter;
import com.microsoft.model.Return;
+import com.microsoft.util.Utils;
import com.sun.source.doctree.DocTree.Kind;
import com.sun.source.doctree.ParamTree;
import com.sun.source.doctree.ReturnTree;
import com.sun.source.doctree.ThrowsTree;
+
import java.util.List;
import java.util.stream.Collectors;
-import javax.lang.model.element.Element;
-import javax.lang.model.element.ExecutableElement;
-import javax.lang.model.element.TypeElement;
-import javax.lang.model.element.VariableElement;
+import javax.lang.model.element.*;
import javax.lang.model.type.TypeKind;
+
import jdk.javadoc.doclet.DocletEnvironment;
public class ClassItemsLookup extends BaseLookup {
+ private Utils utils;
public ClassItemsLookup(DocletEnvironment environment) {
super(environment);
+ utils = new Utils(environment);
}
@Override
@@ -48,18 +50,21 @@ protected ExtendedMetadataFileItem buildMetadataFileItem(Element element) {
ExecutableElement exeElement = (ExecutableElement) element;
List parameters = extractParameters(exeElement);
String paramsString = parameters.stream()
- .map(parameter -> String.format("%s %s", makeTypeShort(parameter.getType()), parameter.getId()))
- .collect(Collectors.joining(", "));
+ .map(parameter -> String.format("%s %s", makeTypeShort(parameter.getType()), parameter.getId()))
+ .collect(Collectors.joining(", "));
String nameWithoutBrackets = elementQName.replaceAll("\\(.*\\)", "");
String methodName = String.format("%s(%s)", nameWithoutBrackets, paramsString);
result.setName(methodName);
result.setMethodContent(String.format("%s %s %s", modifiers,
- makeTypeShort(String.valueOf(exeElement.getReturnType())), result.getName()));
+ makeTypeShort(String.valueOf(exeElement.getReturnType())), result.getName()));
result.setConstructorContent(String.format("%s %s", modifiers, result.getName()));
result.setParameters(parameters);
result.setExceptions(extractExceptions(exeElement));
result.setReturn(extractReturn(exeElement));
+ if (exeElement.getKind() == ElementKind.METHOD) {
+ result.setOverridden(extractOverriddenUid(utils.overriddenMethod(exeElement)));
+ }
}
result.setNameWithType(String.format("%s.%s", classSNameWithGenericsSupport, result.getName()));
result.setFullName(String.format("%s.%s", classQNameWithGenericsSupport, result.getName()));
@@ -83,11 +88,11 @@ List extractParameters(ExecutableElement element) {
String extractParameterDescription(ExecutableElement method, String paramName) {
return getDocCommentTree(method).map(docTree -> docTree.getBlockTags().stream()
- .filter(o -> o.getKind() == Kind.PARAM)
- .map(o -> (ParamTree) o)
- .filter(o -> paramName.equals(String.valueOf(o.getName())))
- .map(o -> replaceLinksAndCodes(o.getDescription()))
- .findFirst().orElse(null)
+ .filter(o -> o.getKind() == Kind.PARAM)
+ .map(o -> (ParamTree) o)
+ .filter(o -> paramName.equals(String.valueOf(o.getName())))
+ .map(o -> replaceLinksAndCodes(o.getDescription()))
+ .findFirst().orElse(null)
).orElse(null);
}
@@ -100,10 +105,10 @@ List extractExceptions(ExecutableElement methodElement) {
String extractExceptionDescription(ExecutableElement methodElement) {
return getDocCommentTree(methodElement).map(docTree -> docTree.getBlockTags().stream()
- .filter(o -> o.getKind() == Kind.THROWS)
- .map(o -> (ThrowsTree) o)
- .map(o -> replaceLinksAndCodes(o.getDescription()))
- .findFirst().orElse(null)
+ .filter(o -> o.getKind() == Kind.THROWS)
+ .map(o -> (ThrowsTree) o)
+ .map(o -> replaceLinksAndCodes(o.getDescription()))
+ .findFirst().orElse(null)
).orElse(null);
}
@@ -116,10 +121,10 @@ Return extractReturn(ExecutableElement methodElement) {
String extractReturnDescription(ExecutableElement methodElement) {
return getDocCommentTree(methodElement).map(docTree -> docTree.getBlockTags().stream()
- .filter(o -> o.getKind() == Kind.RETURN)
- .map(o -> (ReturnTree)o)
- .map(o -> replaceLinksAndCodes(o.getDescription()))
- .findFirst().orElse(null)
+ .filter(o -> o.getKind() == Kind.RETURN)
+ .map(o -> (ReturnTree) o)
+ .map(o -> replaceLinksAndCodes(o.getDescription()))
+ .findFirst().orElse(null)
).orElse(null);
}
@@ -130,4 +135,14 @@ Return extractReturn(VariableElement fieldElement) {
String convertFullNameToOverload(String fullName) {
return fullName.replaceAll("\\(.*\\)", "*");
}
+
+ String extractOverriddenUid(ExecutableElement ovr) {
+ if (ovr != null) {
+ TypeElement te = utils.getEnclosingTypeElement(ovr);
+ String uid = te.getQualifiedName().toString().concat(".") + String.valueOf(ovr);
+ return uid;
+ }
+
+ return "";
+ }
}
diff --git a/src/main/java/com/microsoft/model/MetadataFileItem.java b/src/main/java/com/microsoft/model/MetadataFileItem.java
index 4d2134d..d953ea7 100644
--- a/src/main/java/com/microsoft/model/MetadataFileItem.java
+++ b/src/main/java/com/microsoft/model/MetadataFileItem.java
@@ -11,7 +11,7 @@
import org.apache.commons.lang3.RegExUtils;
@JsonPropertyOrder({"uid", "id", "parent", "children", "href", "langs", "isExternal", "name", "nameWithType",
- "fullName", "overload", "type", "package", "summary", "syntax", "inheritance", "implements", "exceptions",
+ "fullName", "overload", "overridden", "type", "package", "summary", "syntax", "inheritance", "implements", "exceptions",
"spec.java", "inheritedMembers"})
public class MetadataFileItem implements Comparable {
@@ -25,6 +25,7 @@ public class MetadataFileItem implements Comparable {
private String nameWithType;
private String fullName;
private String overload;
+ private String overridden;
private String type;
@JsonProperty("package")
private String packageName;
@@ -232,6 +233,14 @@ public void setReturn(Return returnValue) {
syntax.setReturnValue(returnValue);
}
+ public void setOverridden(String overridden) {
+ this.overridden = overridden;
+ }
+
+ public String getOverridden() {
+ return overridden;
+ }
+
@Override
public boolean equals(Object o) {
if (this == o) {
diff --git a/src/main/java/com/microsoft/util/Utils.java b/src/main/java/com/microsoft/util/Utils.java
index a18edff..0e4b7e3 100644
--- a/src/main/java/com/microsoft/util/Utils.java
+++ b/src/main/java/com/microsoft/util/Utils.java
@@ -1,10 +1,38 @@
package com.microsoft.util;
-import javax.lang.model.element.Element;
-import javax.lang.model.element.Modifier;
+import com.sun.source.doctree.DocCommentTree;
+import com.sun.source.doctree.DocTree;
+
+import javax.lang.model.element.*;
+import javax.lang.model.type.TypeKind;
+import javax.lang.model.type.TypeMirror;
+import javax.lang.model.util.Elements;
+import javax.lang.model.util.SimpleElementVisitor9;
+import javax.lang.model.util.Types;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+import java.util.Optional;
+import java.util.stream.Collectors;
+
+import jdk.javadoc.doclet.DocletEnvironment;
+
+import static com.sun.source.doctree.DocTree.Kind.ERRONEOUS;
+import static javax.lang.model.type.TypeKind.DECLARED;
public class Utils {
+ public final DocletEnvironment docletEnvironment;
+ public final Elements elementUtils;
+ public final Types typeUtils;
+
+ public Utils(DocletEnvironment docEnv) {
+ docletEnvironment = docEnv;
+ elementUtils = docEnv.getElementUtils();
+ typeUtils = docEnv.getTypeUtils();
+ }
+
public static boolean isPackagePrivate(Element e) {
return !(isPublic(e) || isPrivate(e) || isProtected(e));
}
@@ -24,4 +52,157 @@ public static boolean isPublic(Element e) {
public static boolean isPrivateOrPackagePrivate(Element e) {
return isPrivate(e) || isPackagePrivate(e);
}
+
+ public static boolean isNoType(TypeMirror t) {
+ return t.getKind() == TypeKind.NONE;
+ }
+
+ public boolean isStatic(Element e) {
+ return e.getModifiers().contains(Modifier.STATIC);
+ }
+
+ /**
+ * Returns true if the method has no comments, or a lone @inheritDoc.
+ *
+ * @param m a method
+ * @return true if there are no comments, false otherwise
+ */
+ public boolean isSimpleOverride(ExecutableElement m) {
+
+ if (!getBlockTags(m).isEmpty())
+ return false;
+
+ List extends DocTree> fullBody = getFullBody(m);
+ return fullBody.isEmpty() ||
+ (fullBody.size() == 1 && fullBody.get(0).getKind().equals(DocTree.Kind.INHERIT_DOC));
+ }
+
+ public TypeElement getObjectType() {
+ return elementUtils.getTypeElement("java.lang.Object");
+ }
+
+ /**
+ * Return the element of given type.
+ */
+ public TypeElement asTypeElement(TypeMirror t) {
+ if (t.getKind() != TypeKind.NONE) {
+ TypeElement element = (TypeElement) docletEnvironment.getTypeUtils().asElement(t);
+ return element;
+ } else return null;
+ }
+
+ /**
+ * Return the lexically enclosing element for a nested type.
+ * The inherited items will not be listed.
+ */
+ public TypeElement getEnclosingTypeElement(Element e) {
+ if (e.getKind() == ElementKind.PACKAGE)
+ return null;
+ Element encl = e.getEnclosingElement();
+ ElementKind kind = encl.getKind();
+ if (kind == ElementKind.PACKAGE)
+ return null;
+ while (!(kind.isClass() || kind.isInterface())) {
+ encl = encl.getEnclosingElement();
+ kind = encl.getKind();
+ }
+ return (TypeElement) encl;
+ }
+
+ /**
+ * Follow the same behavior with Standard doclet.
+ * Return the ExecutableElement being overridden by given method,
+ * when a method in a class overrides a method in a superclass.
+ * For following cases, they will be marked as "Specified by":
+ *
+ * - a method in an interface overrides a method in a superinterface
+ * - a method in a class implements a method in an interface
+ *
+ * todo add "Specified by" to yaml.
+ */
+ public ExecutableElement overriddenMethod(ExecutableElement method) {
+ if (isStatic(method)) {
+ return null;
+ }
+ final TypeElement origin = getEnclosingTypeElement(method);
+ for (TypeMirror t = getSuperType(origin);
+ t.getKind() == DECLARED;
+ t = getSuperType(asTypeElement(t))) {
+ TypeElement te = asTypeElement(t);
+ if (te == null) {
+ return null;
+ }
+
+ for (Element e : getMembers(te, ElementKind.METHOD)) {
+ ExecutableElement ee = (ExecutableElement) e;
+ if (elementUtils.overrides(method, ee, origin)
+ ) {
+ return ee;
+ }
+ }
+ if (t.equals(getObjectType().asType()))
+ return null;
+ }
+ return null;
+ }
+
+ public TypeMirror getSuperType(TypeElement te) {
+ TypeMirror t = te.getSuperclass();
+ return getType(t);
+ }
+
+ private TypeMirror getType(TypeMirror t) {
+ return (isNoType(t)) ? getObjectType().asType() : t;
+ }
+
+ public Optional getDocCommentTree(Element element) {
+ return Optional.ofNullable(docletEnvironment.getDocTrees().getDocCommentTree(element));
+ }
+
+ protected List extends DocTree> getFullBody(Element element) {
+ return getDocCommentTree(element)
+ .map(DocCommentTree::getFullBody)
+ .orElse(Collections.emptyList());
+ }
+
+ public static List extends DocTree> filteredList(List extends DocTree> dlist, DocTree.Kind... select) {
+ List list = new ArrayList<>();
+ if (select == null)
+ return dlist;
+ for (DocTree dt : dlist) {
+ if (dt.getKind() != ERRONEOUS) {
+ for (DocTree.Kind kind : select) {
+ if (dt.getKind() == kind) {
+ list.add(dt);
+ }
+ }
+ }
+ }
+ return list;
+ }
+
+ private List extends DocTree> getBlockTags0(Element element, DocTree.Kind... kinds) {
+ Optional dcTree = getDocCommentTree(element);
+ if (dcTree.isEmpty())
+ return Collections.emptyList();
+
+ return filteredList(dcTree.get().getBlockTags(), kinds);
+ }
+
+ public List extends DocTree> getBlockTags(Element element) {
+ return getBlockTags0(element, (DocTree.Kind[]) null);
+ }
+
+ /**
+ * Returns a list of visible enclosed members of given kind,
+ * declared in this type element, and does not include
+ * any inherited members or extra members.
+ *
+ * @return a list of visible enclosed members in this type
+ */
+ public List extends Element> getMembers(TypeElement te, ElementKind kind) {
+ return te.getEnclosedElements().stream()
+ .filter(e -> e.getKind() == kind && !isPrivateOrPackagePrivate(e))
+ .collect(Collectors.toList());
+ }
}
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.BasePartnerComponentString.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.BasePartnerComponentString.yml
index d1f9f3d..6cee6d7 100644
--- a/src/test/resources/expected-generated-files/com.microsoft.samples.BasePartnerComponentString.yml
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.BasePartnerComponentString.yml
@@ -82,6 +82,7 @@ items:
nameWithType: "BasePartnerComponentString.testInherited()"
fullName: "com.microsoft.samples.BasePartnerComponentString.testInherited()"
overload: "com.microsoft.samples.BasePartnerComponentString.testInherited*"
+ overridden: "com.microsoft.samples.BasePartnerComponent.testInherited()"
type: "Method"
package: "com.microsoft.samples"
syntax:
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml
index 9cab56c..6a03c93 100644
--- a/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.SuperHero.yml
@@ -155,6 +155,7 @@ items:
nameWithType: "SuperHero.getLastName()"
fullName: "com.microsoft.samples.SuperHero.getLastName()"
overload: "com.microsoft.samples.SuperHero.getLastName*"
+ overridden: "com.microsoft.samples.subpackage.Person.getLastName()"
type: "Method"
package: "com.microsoft.samples"
summary: "Get capitalized last name. But it's not the end, because of multiline comment"
From 7732efa6cef635abca61246c26ec7a34a900ed21 Mon Sep 17 00:00:00 2001
From: anmeng10101 <33647870+anmeng10101@users.noreply.github.com>
Date: Thu, 4 Jun 2020 13:06:08 +0800
Subject: [PATCH 4/4] implement comment inheritance for methods (#40)
---
.../microsoft/lookup/ClassItemsLookup.java | 50 +++
.../com/microsoft/util/CommentHelper.java | 89 +++++
src/main/java/com/microsoft/util/Utils.java | 61 +++-
.../samples/commentinheritance/Animal.java | 28 ++
.../commentinheritance/Carnivorous.java | 18 +
.../samples/commentinheritance/Dog.java | 71 ++++
.../commentinheritance/Herbivorous.java | 22 ++
.../samples/commentinheritance/Mammal.java | 13 +
.../commentinheritance/Omnivorous.java | 19 ++
.../samples/commentinheritance/Organism.java | 9 +
.../commentinheritance/Viviparous.java | 14 +
...soft.samples.commentinheritance.Animal.yml | 187 +++++++++++
...samples.commentinheritance.Carnivorous.yml | 72 ++++
...crosoft.samples.commentinheritance.Dog.yml | 308 ++++++++++++++++++
...s.commentinheritance.Herbivorous.Plant.yml | 93 ++++++
...samples.commentinheritance.Herbivorous.yml | 73 +++++
...soft.samples.commentinheritance.Mammal.yml | 147 +++++++++
....samples.commentinheritance.Omnivorous.yml | 104 ++++++
...ft.samples.commentinheritance.Organism.yml | 43 +++
....samples.commentinheritance.Viviparous.yml | 71 ++++
...m.microsoft.samples.commentinheritance.yml | 59 ++++
.../expected-generated-files/toc.yml | 21 ++
22 files changed, 1568 insertions(+), 4 deletions(-)
create mode 100644 src/main/java/com/microsoft/util/CommentHelper.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Animal.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Carnivorous.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Dog.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Herbivorous.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Mammal.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Omnivorous.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Organism.java
create mode 100644 src/test/java/com/microsoft/samples/commentinheritance/Viviparous.java
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Animal.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Carnivorous.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Dog.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.Plant.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Mammal.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Omnivorous.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Organism.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Viviparous.yml
create mode 100644 src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.yml
diff --git a/src/main/java/com/microsoft/lookup/ClassItemsLookup.java b/src/main/java/com/microsoft/lookup/ClassItemsLookup.java
index 1b23454..18436b9 100644
--- a/src/main/java/com/microsoft/lookup/ClassItemsLookup.java
+++ b/src/main/java/com/microsoft/lookup/ClassItemsLookup.java
@@ -1,17 +1,24 @@
package com.microsoft.lookup;
import com.microsoft.lookup.model.ExtendedMetadataFileItem;
+
import com.microsoft.model.ExceptionItem;
import com.microsoft.model.MethodParameter;
import com.microsoft.model.Return;
+
+import com.microsoft.util.CommentHelper;
import com.microsoft.util.Utils;
+
+import com.sun.source.doctree.DocTree;
import com.sun.source.doctree.DocTree.Kind;
import com.sun.source.doctree.ParamTree;
import com.sun.source.doctree.ReturnTree;
import com.sun.source.doctree.ThrowsTree;
+import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
+
import javax.lang.model.element.*;
import javax.lang.model.type.TypeKind;
@@ -64,6 +71,7 @@ protected ExtendedMetadataFileItem buildMetadataFileItem(Element element) {
result.setReturn(extractReturn(exeElement));
if (exeElement.getKind() == ElementKind.METHOD) {
result.setOverridden(extractOverriddenUid(utils.overriddenMethod(exeElement)));
+ result.setSummary(getInheritedInlineCommentString(exeElement));
}
}
result.setNameWithType(String.format("%s.%s", classSNameWithGenericsSupport, result.getName()));
@@ -145,4 +153,46 @@ String extractOverriddenUid(ExecutableElement ovr) {
return "";
}
+
+ /**
+ * If the item being inherited from is declared from external compiled package,
+ * or is declared in the packages like java.lang.Object,
+ * comments may be not available as doclet resolves from byte code.
+ */
+ String getInheritedInlineCommentString(ExecutableElement exeElement) {
+ CommentHelper ch = getInheritedInlineTags(new CommentHelper(exeElement, utils));
+ // Remove unresolved "@inheritDoc" tag.
+ List extends DocTree> dctree = utils.removeBlockTag(ch.inlineTags, DocTree.Kind.INHERIT_DOC);
+ return replaceLinksAndCodes(dctree);
+ }
+
+ CommentHelper getInheritedInlineTags(CommentHelper input) {
+ CommentHelper output = input.copy();
+ if (!output.hasInheritDocTag()&& !output.isSimpleOverride()) {
+ return output;
+ }
+
+ CommentHelper inheritedSearchInput = input.copy();
+ ExecutableElement overriddenMethod = utils.overriddenMethod((ExecutableElement) input.element);
+
+ if (overriddenMethod != null) {
+ inheritedSearchInput.element = overriddenMethod;
+ CommentHelper ch = getInheritedInlineTags(inheritedSearchInput);
+ if (!ch.isSimpleOverride()) {
+ output = output.inherit(ch);
+ }
+ }
+
+ TypeElement encl = utils.getEnclosingTypeElement(input.element);
+ List implementedMethods = utils.getImplementedMethods(input.element.toString(), encl, new ArrayList());
+ for (Element implementedMethod : implementedMethods) {
+ inheritedSearchInput.element = implementedMethod;
+ CommentHelper ch = getInheritedInlineTags(inheritedSearchInput);
+ if (!ch.isSimpleOverride()) {
+ output = output.inherit(ch);
+ }
+ }
+
+ return output;
+ }
}
diff --git a/src/main/java/com/microsoft/util/CommentHelper.java b/src/main/java/com/microsoft/util/CommentHelper.java
new file mode 100644
index 0000000..f15ff25
--- /dev/null
+++ b/src/main/java/com/microsoft/util/CommentHelper.java
@@ -0,0 +1,89 @@
+package com.microsoft.util;
+
+import com.sun.source.doctree.DocTree;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+import java.util.stream.Collectors;
+
+import javax.lang.model.element.Element;
+
+public class CommentHelper {
+ public Element element;
+ public List extends DocTree> inlineTags = Collections.emptyList();
+ private Utils utils;
+ private boolean hasInheritDocTag = false;
+
+ public CommentHelper(Element element, Utils utils) {
+ this.element = element;
+ this.utils = utils;
+ this.inlineTags = utils.getFullBody(element);
+ this.hasInheritDocTag = utils.hasInlineTag(inlineTags, DocTree.Kind.INHERIT_DOC);
+ }
+
+ public CommentHelper(Element element, Utils utils, List extends DocTree> inlineTags) {
+ this.element = element;
+ this.utils = utils;
+ this.inlineTags = inlineTags;
+ this.hasInheritDocTag = utils.hasInlineTag(inlineTags, DocTree.Kind.INHERIT_DOC);
+ }
+
+ /**
+ * Returns true if the method has no comments, or a lone @inheritDoc.
+ *
+ * @return true if there are no comments, false otherwise
+ */
+ public boolean isSimpleOverride() {
+ return inlineTags.isEmpty() ||
+ (inlineTags.size() == 1 && hasInheritDocTag);
+ }
+
+ public boolean hasInheritDocTag(){
+ return this.hasInheritDocTag;
+ }
+
+ public CommentHelper copy() {
+ if (this.element == null) {
+ throw new NullPointerException();
+ }
+ CommentHelper clone = new CommentHelper(this.element, this.utils);
+ return clone;
+ }
+
+ public CommentHelper inherit(CommentHelper chInheritFrom) {
+ List extends DocTree> mergedTags = new ArrayList<>();
+
+ if (this.isSimpleOverride())
+ mergedTags = chInheritFrom.inlineTags;
+ else {
+ mergedTags = inheritInlineTags(this, chInheritFrom);
+ }
+
+ return new CommentHelper(this.element, this.utils, mergedTags);
+ }
+
+ List extends DocTree> inheritInlineTags(CommentHelper origin, CommentHelper chInheritFrom) {
+ List mergedTags = new ArrayList<>();
+ if (!origin.isSimpleOverride() && !origin.hasInheritDocTag) {
+ return origin.inlineTags;
+ }
+
+ // Get the index of "{@inheritedDoc}".
+ int index = origin.inlineTags.stream().map(e -> e.getKind())
+ .collect(Collectors.toList())
+ .indexOf(DocTree.Kind.INHERIT_DOC);
+
+ // Replace the "{@inheritedDoc}" with inherited inlineTags.
+ mergedTags = origin.inlineTags.stream().collect(Collectors.toList());
+ mergedTags.remove(index);
+
+ for (DocTree d : chInheritFrom.inlineTags
+ ) {
+ mergedTags.add(index, d);
+ index++;
+ }
+
+ return mergedTags;
+ }
+}
diff --git a/src/main/java/com/microsoft/util/Utils.java b/src/main/java/com/microsoft/util/Utils.java
index 0e4b7e3..df8e08b 100644
--- a/src/main/java/com/microsoft/util/Utils.java
+++ b/src/main/java/com/microsoft/util/Utils.java
@@ -10,10 +10,7 @@
import javax.lang.model.util.SimpleElementVisitor9;
import javax.lang.model.util.Types;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-import java.util.Optional;
+import java.util.*;
import java.util.stream.Collectors;
import jdk.javadoc.doclet.DocletEnvironment;
@@ -77,6 +74,21 @@ public boolean isSimpleOverride(ExecutableElement m) {
(fullBody.size() == 1 && fullBody.get(0).getKind().equals(DocTree.Kind.INHERIT_DOC));
}
+ public boolean hasInlineTag(List extends DocTree> inlineTags, DocTree.Kind kind) {
+ for (DocTree dt : inlineTags) {
+ if (dt.getKind() == kind) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ public Element getMemberBySignature(TypeElement te, ElementKind kind, String signature) {
+ return getMembers(te, kind).stream()
+ .filter(e -> e.toString().equals(signature))
+ .findFirst().orElse(null);
+ }
+
public TypeElement getObjectType() {
return elementUtils.getTypeElement("java.lang.Object");
}
@@ -193,6 +205,12 @@ public List extends DocTree> getBlockTags(Element element) {
return getBlockTags0(element, (DocTree.Kind[]) null);
}
+ public List extends DocTree> removeBlockTag(List extends DocTree> dctree, DocTree.Kind kind) {
+ return dctree.stream()
+ .filter(dc -> !dc.getKind().equals(kind))
+ .collect(Collectors.toList());
+ }
+
/**
* Returns a list of visible enclosed members of given kind,
* declared in this type element, and does not include
@@ -205,4 +223,39 @@ public List extends Element> getMembers(TypeElement te, ElementKind kind) {
.filter(e -> e.getKind() == kind && !isPrivateOrPackagePrivate(e))
.collect(Collectors.toList());
}
+
+ /**
+ * Returns a list of methods being implemented by given method.
+ * When a method in an interface overrides a method its superinterface,
+ * it will be considered as "implemented", instead of "overridden".
+ *
+ * @return a list of implemented methods
+ */
+ public List getImplementedMethods(String signature, TypeElement encl, List implementedMethods) {
+ if (encl == null) {
+ return implementedMethods;
+ }
+
+ for (TypeElement interfaceType : getImplementedInterfaces(encl)) {
+ Element implementedMethod = getMemberBySignature(interfaceType, ElementKind.METHOD, signature);
+ if (implementedMethod != null) {
+ implementedMethods.add(implementedMethod);
+ }
+ // We need to search every implemented interface of the Inheritance chain.
+ getImplementedMethods(signature, interfaceType, implementedMethods);
+ }
+ return implementedMethods;
+ }
+
+ /**
+ * Returns a list of implemented interface type elements of given type element.
+ * Follow Standard doclet, search in the order of appearance following the word implements in declaration.
+ *
+ * @return a list of implemented interfaces
+ */
+ public List getImplementedInterfaces(TypeElement element) {
+ return element.getInterfaces().stream()
+ .map(e -> asTypeElement(e))
+ .collect(Collectors.toList());
+ }
}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Animal.java b/src/test/java/com/microsoft/samples/commentinheritance/Animal.java
new file mode 100644
index 0000000..8e2c8fb
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Animal.java
@@ -0,0 +1,28 @@
+package com.microsoft.samples.commentinheritance;
+
+/**
+ * Animal.
+ */
+public abstract class Animal implements Organism{
+ /**
+ * Breathe.
+ */
+ public void breathe() {
+ }
+
+ /**
+ * Communicate verbally.
+ */
+ public abstract void verballyCommunicate();
+
+ /**
+ * Feed offspring.
+ */
+ public abstract void feed();
+
+ /**
+ * {@inheritDoc}
+ * Get kind from Animal.
+ */
+ public abstract String getKind();
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Carnivorous.java b/src/test/java/com/microsoft/samples/commentinheritance/Carnivorous.java
new file mode 100644
index 0000000..96811e0
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Carnivorous.java
@@ -0,0 +1,18 @@
+package com.microsoft.samples.commentinheritance;
+
+/**
+ * Marks an Animal that eats other animals.
+ */
+public interface Carnivorous {
+ /**
+ * Eat the provided animal.
+ *
+ * @param animalBeingEaten Animal that will be eaten.
+ */
+ void eat(Animal animalBeingEaten);
+
+ /**
+ * Get kind from Carnivorous.
+ */
+ String getKind();
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Dog.java b/src/test/java/com/microsoft/samples/commentinheritance/Dog.java
new file mode 100644
index 0000000..da6ca7a
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Dog.java
@@ -0,0 +1,71 @@
+package com.microsoft.samples.commentinheritance;
+
+import java.awt.Color;
+
+import static java.lang.System.out;
+
+/**
+ * Canine and man's best friend.
+ */
+public class Dog extends Mammal implements Omnivorous, Viviparous {
+ private final Color hairColor = null;
+
+ /**
+ * {@inheritDoc}
+ *
+ * @param otherAnimal Tasty treat.
+ */
+ @Override
+ public void eat(final Animal otherAnimal) {
+ }
+
+ /**
+ * {@inheritDoc}
+ *
+ * @param plantToBeEaten Plant that this dog will eat.
+ */
+ @Override
+ public void eat(final Plant plantToBeEaten) {
+ }
+
+ /**
+ * {@inheritDoc} Bark.
+ */
+ public void verballyCommunicate() {
+ out.println("Woof!");
+ }
+
+ /**
+ * {@inheritDoc}
+ *
+ * @param numberPuppies Number of puppies being born.
+ */
+ @Override
+ public void giveBirth(final int numberPuppies) {
+ }
+
+ /**
+ * Provide the color of the dog's hair.
+ *
+ * @return Color of the dog's fur.
+ */
+ public Color getHairColor() {
+ return hairColor;
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ public void feed() {
+ }
+
+ /**
+ * {@inheritDoc}
+ * Get kind from Dog.
+ */
+ @Override
+ public String getKind() {
+ return "Dog";
+ }
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Herbivorous.java b/src/test/java/com/microsoft/samples/commentinheritance/Herbivorous.java
new file mode 100644
index 0000000..32abea1
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Herbivorous.java
@@ -0,0 +1,22 @@
+package com.microsoft.samples.commentinheritance;
+
+/**
+ * Marks animals that eat plants.
+ */
+public interface Herbivorous {
+ /**
+ * Eat the provided plant.
+ *
+ * @param plantToBeEaten Plant that will be eaten.
+ */
+ void eat(Plant plantToBeEaten);
+
+ /**
+ * Get kind from Herbivorous.
+ */
+ String getKind();
+
+ public class Plant {
+ }
+
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Mammal.java b/src/test/java/com/microsoft/samples/commentinheritance/Mammal.java
new file mode 100644
index 0000000..a72edc1
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Mammal.java
@@ -0,0 +1,13 @@
+package com.microsoft.samples.commentinheritance;
+
+/**
+ * Mammal.
+ */
+public abstract class Mammal extends Animal {
+
+ /**
+ * {@inheritDoc}
+ * Get kind from Mammal.
+ */
+ public abstract String getKind();
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Omnivorous.java b/src/test/java/com/microsoft/samples/commentinheritance/Omnivorous.java
new file mode 100644
index 0000000..b5686eb
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Omnivorous.java
@@ -0,0 +1,19 @@
+package com.microsoft.samples.commentinheritance;
+
+/**
+ * Eats plants and animals.
+ */
+public interface Omnivorous extends Carnivorous, Herbivorous {
+ @Override
+ void eat(Animal animalToBeEaten);
+
+ @Override
+ void eat(Plant plantToBeEaten);
+
+ /**
+ * {@inheritDoc}
+ * Get kind from Omnivorous.
+ */
+ @Override
+ String getKind();
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Organism.java b/src/test/java/com/microsoft/samples/commentinheritance/Organism.java
new file mode 100644
index 0000000..8edf9a6
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Organism.java
@@ -0,0 +1,9 @@
+package com.microsoft.samples.commentinheritance;
+
+public interface Organism {
+
+ /**
+ * Get kind from Organism.
+ */
+ String getKind();
+}
diff --git a/src/test/java/com/microsoft/samples/commentinheritance/Viviparous.java b/src/test/java/com/microsoft/samples/commentinheritance/Viviparous.java
new file mode 100644
index 0000000..685eba4
--- /dev/null
+++ b/src/test/java/com/microsoft/samples/commentinheritance/Viviparous.java
@@ -0,0 +1,14 @@
+package com.microsoft.samples.commentinheritance;
+
+/**
+ * Mammals that give birth to young that develop within the mother's body.
+ */
+public interface Viviparous {
+
+ void giveBirth(int numberOfOffspring);
+
+ /**
+ * Get kind from Viviparous.
+ */
+ String getKind();
+}
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Animal.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Animal.yml
new file mode 100644
index 0000000..61424db
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Animal.yml
@@ -0,0 +1,187 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Animal"
+ id: "Animal"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Animal.Animal()"
+ - "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ - "com.microsoft.samples.commentinheritance.Animal.feed()"
+ - "com.microsoft.samples.commentinheritance.Animal.getKind()"
+ - "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ langs:
+ - "java"
+ name: "Animal"
+ nameWithType: "Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal"
+ type: "Class"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Animal."
+ syntax:
+ content: "public abstract class Animal implements Organism"
+ inheritance:
+ - "java.lang.Object"
+ implements:
+ - "com.microsoft.samples.commentinheritance.Organism"
+ inheritedMembers:
+ - "java.lang.Object.clone()"
+ - "java.lang.Object.equals(java.lang.Object)"
+ - "java.lang.Object.finalize()"
+ - "java.lang.Object.getClass()"
+ - "java.lang.Object.hashCode()"
+ - "java.lang.Object.notify()"
+ - "java.lang.Object.notifyAll()"
+ - "java.lang.Object.toString()"
+ - "java.lang.Object.wait()"
+ - "java.lang.Object.wait(long)"
+ - "java.lang.Object.wait(long,int)"
+- uid: "com.microsoft.samples.commentinheritance.Animal.Animal()"
+ id: "Animal()"
+ parent: "com.microsoft.samples.commentinheritance.Animal"
+ langs:
+ - "java"
+ name: "Animal()"
+ nameWithType: "Animal.Animal()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.Animal()"
+ overload: "com.microsoft.samples.commentinheritance.Animal.Animal*"
+ type: "Constructor"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public Animal()"
+- uid: "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ id: "breathe()"
+ parent: "com.microsoft.samples.commentinheritance.Animal"
+ langs:
+ - "java"
+ name: "breathe()"
+ nameWithType: "Animal.breathe()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ overload: "com.microsoft.samples.commentinheritance.Animal.breathe*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Breathe."
+ syntax:
+ content: "public void breathe()"
+- uid: "com.microsoft.samples.commentinheritance.Animal.feed()"
+ id: "feed()"
+ parent: "com.microsoft.samples.commentinheritance.Animal"
+ langs:
+ - "java"
+ name: "feed()"
+ nameWithType: "Animal.feed()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.feed()"
+ overload: "com.microsoft.samples.commentinheritance.Animal.feed*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Feed offspring."
+ syntax:
+ content: "public abstract void feed()"
+- uid: "com.microsoft.samples.commentinheritance.Animal.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Animal"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Animal.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Animal.getKind*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Organism. Get kind from Animal."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ id: "verballyCommunicate()"
+ parent: "com.microsoft.samples.commentinheritance.Animal"
+ langs:
+ - "java"
+ name: "verballyCommunicate()"
+ nameWithType: "Animal.verballyCommunicate()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ overload: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Communicate verbally."
+ syntax:
+ content: "public abstract void verballyCommunicate()"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Animal.Animal*"
+ name: "Animal"
+ nameWithType: "Animal.Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.Animal"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Animal.breathe*"
+ name: "breathe"
+ nameWithType: "Animal.breathe"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.breathe"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate*"
+ name: "verballyCommunicate"
+ nameWithType: "Animal.verballyCommunicate"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Animal.feed*"
+ name: "feed"
+ nameWithType: "Animal.feed"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.feed"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Animal.getKind*"
+ name: "getKind"
+ nameWithType: "Animal.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.getKind"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Organism"
+ name: "Organism"
+ nameWithType: "Organism"
+ fullName: "com.microsoft.samples.commentinheritance.Organism"
+- uid: "java.lang.Object.notify()"
+ name: "Object.notify()"
+ nameWithType: "Object.notify()"
+ fullName: "java.lang.Object.notify()"
+- uid: "java.lang.Object.wait()"
+ name: "Object.wait()"
+ nameWithType: "Object.wait()"
+ fullName: "java.lang.Object.wait()"
+- uid: "java.lang.Object.finalize()"
+ name: "Object.finalize()"
+ nameWithType: "Object.finalize()"
+ fullName: "java.lang.Object.finalize()"
+- uid: "java.lang.Object.clone()"
+ name: "Object.clone()"
+ nameWithType: "Object.clone()"
+ fullName: "java.lang.Object.clone()"
+- uid: "java.lang.Object.notifyAll()"
+ name: "Object.notifyAll()"
+ nameWithType: "Object.notifyAll()"
+ fullName: "java.lang.Object.notifyAll()"
+- uid: "java.lang.Object.equals(java.lang.Object)"
+ name: "Object.equals(Object)"
+ nameWithType: "Object.equals(Object)"
+ fullName: "java.lang.Object.equals(java.lang.Object)"
+- uid: "java.lang.Object.getClass()"
+ name: "Object.getClass()"
+ nameWithType: "Object.getClass()"
+ fullName: "java.lang.Object.getClass()"
+- uid: "java.lang.Object.wait(long)"
+ name: "Object.wait(long)"
+ nameWithType: "Object.wait(long)"
+ fullName: "java.lang.Object.wait(long)"
+- uid: "java.lang.Object.hashCode()"
+ name: "Object.hashCode()"
+ nameWithType: "Object.hashCode()"
+ fullName: "java.lang.Object.hashCode()"
+- uid: "java.lang.Object.wait(long,int)"
+ name: "Object.wait(long,int)"
+ nameWithType: "Object.wait(long,int)"
+ fullName: "java.lang.Object.wait(long,int)"
+- uid: "java.lang.Object.toString()"
+ name: "Object.toString()"
+ nameWithType: "Object.toString()"
+ fullName: "java.lang.Object.toString()"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Carnivorous.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Carnivorous.yml
new file mode 100644
index 0000000..2d9e801
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Carnivorous.yml
@@ -0,0 +1,72 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous"
+ id: "Carnivorous"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Carnivorous.eat(com.microsoft.samples.commentinheritance.Animal)"
+ - "com.microsoft.samples.commentinheritance.Carnivorous.getKind()"
+ langs:
+ - "java"
+ name: "Carnivorous"
+ nameWithType: "Carnivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous"
+ type: "Interface"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Marks an Animal that eats other animals."
+ syntax:
+ content: "public interface Carnivorous"
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous.eat(com.microsoft.samples.commentinheritance.Animal)"
+ id: "eat(com.microsoft.samples.commentinheritance.Animal)"
+ parent: "com.microsoft.samples.commentinheritance.Carnivorous"
+ langs:
+ - "java"
+ name: "eat(Animal animalBeingEaten)"
+ nameWithType: "Carnivorous.eat(Animal animalBeingEaten)"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous.eat(Animal animalBeingEaten)"
+ overload: "com.microsoft.samples.commentinheritance.Carnivorous.eat*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eat the provided animal."
+ syntax:
+ content: "public abstract void eat(Animal animalBeingEaten)"
+ parameters:
+ - id: "animalBeingEaten"
+ type: "com.microsoft.samples.commentinheritance.Animal"
+ description: "Animal that will be eaten."
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Carnivorous"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Carnivorous.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Carnivorous.getKind*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Carnivorous."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Animal"
+ name: "Animal"
+ nameWithType: "Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal"
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous.eat*"
+ name: "eat"
+ nameWithType: "Carnivorous.eat"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous.eat"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous.getKind*"
+ name: "getKind"
+ nameWithType: "Carnivorous.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous.getKind"
+ package: "com.microsoft.samples.commentinheritance"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Dog.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Dog.yml
new file mode 100644
index 0000000..dbd9414
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Dog.yml
@@ -0,0 +1,308 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Dog"
+ id: "Dog"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Dog.Dog()"
+ - "com.microsoft.samples.commentinheritance.Dog.eat(com.microsoft.samples.commentinheritance.Animal)"
+ - "com.microsoft.samples.commentinheritance.Dog.eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ - "com.microsoft.samples.commentinheritance.Dog.feed()"
+ - "com.microsoft.samples.commentinheritance.Dog.getHairColor()"
+ - "com.microsoft.samples.commentinheritance.Dog.getKind()"
+ - "com.microsoft.samples.commentinheritance.Dog.giveBirth(int)"
+ - "com.microsoft.samples.commentinheritance.Dog.verballyCommunicate()"
+ langs:
+ - "java"
+ name: "Dog"
+ nameWithType: "Dog"
+ fullName: "com.microsoft.samples.commentinheritance.Dog"
+ type: "Class"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Canine and man's best friend."
+ syntax:
+ content: "public class Dog extends Mammal implements Omnivorous, Viviparous"
+ inheritance:
+ - "java.lang.Object"
+ - "com.microsoft.samples.commentinheritance.Animal"
+ - "com.microsoft.samples.commentinheritance.Mammal"
+ implements:
+ - "com.microsoft.samples.commentinheritance.Omnivorous"
+ - "com.microsoft.samples.commentinheritance.Viviparous"
+ inheritedMembers:
+ - "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ - "com.microsoft.samples.commentinheritance.Animal.feed()"
+ - "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ - "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+ - "java.lang.Object.clone()"
+ - "java.lang.Object.equals(java.lang.Object)"
+ - "java.lang.Object.finalize()"
+ - "java.lang.Object.getClass()"
+ - "java.lang.Object.hashCode()"
+ - "java.lang.Object.notify()"
+ - "java.lang.Object.notifyAll()"
+ - "java.lang.Object.toString()"
+ - "java.lang.Object.wait()"
+ - "java.lang.Object.wait(long)"
+ - "java.lang.Object.wait(long,int)"
+- uid: "com.microsoft.samples.commentinheritance.Dog.Dog()"
+ id: "Dog()"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "Dog()"
+ nameWithType: "Dog.Dog()"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.Dog()"
+ overload: "com.microsoft.samples.commentinheritance.Dog.Dog*"
+ type: "Constructor"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public Dog()"
+- uid: "com.microsoft.samples.commentinheritance.Dog.eat(com.microsoft.samples.commentinheritance.Animal)"
+ id: "eat(com.microsoft.samples.commentinheritance.Animal)"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "eat(Animal otherAnimal)"
+ nameWithType: "Dog.eat(Animal otherAnimal)"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.eat(Animal otherAnimal)"
+ overload: "com.microsoft.samples.commentinheritance.Dog.eat*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eat the provided animal."
+ syntax:
+ content: "public void eat(Animal otherAnimal)"
+ parameters:
+ - id: "otherAnimal"
+ type: "com.microsoft.samples.commentinheritance.Animal"
+ description: "Tasty treat."
+- uid: "com.microsoft.samples.commentinheritance.Dog.eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ id: "eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "eat(Herbivorous.Plant plantToBeEaten)"
+ nameWithType: "Dog.eat(Herbivorous.Plant plantToBeEaten)"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.eat(Herbivorous.Plant plantToBeEaten)"
+ overload: "com.microsoft.samples.commentinheritance.Dog.eat*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eat the provided plant."
+ syntax:
+ content: "public void eat(Herbivorous.Plant plantToBeEaten)"
+ parameters:
+ - id: "plantToBeEaten"
+ type: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ description: "Plant that this dog will eat."
+- uid: "com.microsoft.samples.commentinheritance.Dog.feed()"
+ id: "feed()"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "feed()"
+ nameWithType: "Dog.feed()"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.feed()"
+ overload: "com.microsoft.samples.commentinheritance.Dog.feed*"
+ overridden: "com.microsoft.samples.commentinheritance.Animal.feed()"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Feed offspring."
+ syntax:
+ content: "public void feed()"
+- uid: "com.microsoft.samples.commentinheritance.Dog.getHairColor()"
+ id: "getHairColor()"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "getHairColor()"
+ nameWithType: "Dog.getHairColor()"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.getHairColor()"
+ overload: "com.microsoft.samples.commentinheritance.Dog.getHairColor*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Provide the color of the dog's hair."
+ syntax:
+ content: "public Color getHairColor()"
+ return:
+ type: "java.awt.Color"
+ description: "Color of the dog's fur."
+- uid: "com.microsoft.samples.commentinheritance.Dog.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Dog.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Dog.getKind*"
+ overridden: "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Organism. Get kind from Animal. Get kind from Mammal. Get kind from Dog."
+ syntax:
+ content: "public String getKind()"
+ return:
+ type: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Dog.giveBirth(int)"
+ id: "giveBirth(int)"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "giveBirth(int numberPuppies)"
+ nameWithType: "Dog.giveBirth(int numberPuppies)"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.giveBirth(int numberPuppies)"
+ overload: "com.microsoft.samples.commentinheritance.Dog.giveBirth*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public void giveBirth(int numberPuppies)"
+ parameters:
+ - id: "numberPuppies"
+ type: "int"
+ description: "Number of puppies being born."
+- uid: "com.microsoft.samples.commentinheritance.Dog.verballyCommunicate()"
+ id: "verballyCommunicate()"
+ parent: "com.microsoft.samples.commentinheritance.Dog"
+ langs:
+ - "java"
+ name: "verballyCommunicate()"
+ nameWithType: "Dog.verballyCommunicate()"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.verballyCommunicate()"
+ overload: "com.microsoft.samples.commentinheritance.Dog.verballyCommunicate*"
+ overridden: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Communicate verbally. Bark."
+ syntax:
+ content: "public void verballyCommunicate()"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Dog.Dog*"
+ name: "Dog"
+ nameWithType: "Dog.Dog"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.Dog"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Animal"
+ name: "Animal"
+ nameWithType: "Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal"
+- uid: "com.microsoft.samples.commentinheritance.Dog.eat*"
+ name: "eat"
+ nameWithType: "Dog.eat"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.eat"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ name: "Herbivorous.Plant"
+ nameWithType: "Herbivorous.Plant"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+- uid: "com.microsoft.samples.commentinheritance.Dog.verballyCommunicate*"
+ name: "verballyCommunicate"
+ nameWithType: "Dog.verballyCommunicate"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.verballyCommunicate"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "int"
+ spec.java:
+ - uid: "int"
+ name: "int"
+ fullName: "int"
+- uid: "com.microsoft.samples.commentinheritance.Dog.giveBirth*"
+ name: "giveBirth"
+ nameWithType: "Dog.giveBirth"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.giveBirth"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.awt.Color"
+ spec.java:
+ - uid: "java.awt.Color"
+ name: "Color"
+ fullName: "java.awt.Color"
+- uid: "com.microsoft.samples.commentinheritance.Dog.getHairColor*"
+ name: "getHairColor"
+ nameWithType: "Dog.getHairColor"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.getHairColor"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Dog.feed*"
+ name: "feed"
+ nameWithType: "Dog.feed"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.feed"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Dog.getKind*"
+ name: "getKind"
+ nameWithType: "Dog.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Dog.getKind"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Mammal"
+ name: "Mammal"
+ nameWithType: "Mammal"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous"
+ name: "Omnivorous"
+ nameWithType: "Omnivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous"
+- uid: "com.microsoft.samples.commentinheritance.Viviparous"
+ name: "Viviparous"
+ nameWithType: "Viviparous"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous"
+- uid: "java.lang.Object.notify()"
+ name: "Object.notify()"
+ nameWithType: "Object.notify()"
+ fullName: "java.lang.Object.notify()"
+- uid: "java.lang.Object.wait()"
+ name: "Object.wait()"
+ nameWithType: "Object.wait()"
+ fullName: "java.lang.Object.wait()"
+- uid: "java.lang.Object.finalize()"
+ name: "Object.finalize()"
+ nameWithType: "Object.finalize()"
+ fullName: "java.lang.Object.finalize()"
+- uid: "java.lang.Object.notifyAll()"
+ name: "Object.notifyAll()"
+ nameWithType: "Object.notifyAll()"
+ fullName: "java.lang.Object.notifyAll()"
+- uid: "java.lang.Object.clone()"
+ name: "Object.clone()"
+ nameWithType: "Object.clone()"
+ fullName: "java.lang.Object.clone()"
+- uid: "java.lang.Object.equals(java.lang.Object)"
+ name: "Object.equals(Object)"
+ nameWithType: "Object.equals(Object)"
+ fullName: "java.lang.Object.equals(java.lang.Object)"
+- uid: "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ name: "Animal.breathe()"
+ nameWithType: "Animal.breathe()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.breathe()"
+- uid: "java.lang.Object.toString()"
+ name: "Object.toString()"
+ nameWithType: "Object.toString()"
+ fullName: "java.lang.Object.toString()"
+- uid: "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+ name: "Mammal.getKind()"
+ nameWithType: "Mammal.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+- uid: "java.lang.Object.getClass()"
+ name: "Object.getClass()"
+ nameWithType: "Object.getClass()"
+ fullName: "java.lang.Object.getClass()"
+- uid: "java.lang.Object.wait(long)"
+ name: "Object.wait(long)"
+ nameWithType: "Object.wait(long)"
+ fullName: "java.lang.Object.wait(long)"
+- uid: "java.lang.Object.hashCode()"
+ name: "Object.hashCode()"
+ nameWithType: "Object.hashCode()"
+ fullName: "java.lang.Object.hashCode()"
+- uid: "java.lang.Object.wait(long,int)"
+ name: "Object.wait(long,int)"
+ nameWithType: "Object.wait(long,int)"
+ fullName: "java.lang.Object.wait(long,int)"
+- uid: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ name: "Animal.verballyCommunicate()"
+ nameWithType: "Animal.verballyCommunicate()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+- uid: "com.microsoft.samples.commentinheritance.Animal.feed()"
+ name: "Animal.feed()"
+ nameWithType: "Animal.feed()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.feed()"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.Plant.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.Plant.yml
new file mode 100644
index 0000000..780526c
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.Plant.yml
@@ -0,0 +1,93 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ id: "Plant"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Herbivorous.Plant.Plant()"
+ langs:
+ - "java"
+ name: "Herbivorous.Plant"
+ nameWithType: "Herbivorous.Plant"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ type: "Class"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public static class Herbivorous.Plant"
+ inheritance:
+ - "java.lang.Object"
+ inheritedMembers:
+ - "java.lang.Object.clone()"
+ - "java.lang.Object.equals(java.lang.Object)"
+ - "java.lang.Object.finalize()"
+ - "java.lang.Object.getClass()"
+ - "java.lang.Object.hashCode()"
+ - "java.lang.Object.notify()"
+ - "java.lang.Object.notifyAll()"
+ - "java.lang.Object.toString()"
+ - "java.lang.Object.wait()"
+ - "java.lang.Object.wait(long)"
+ - "java.lang.Object.wait(long,int)"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant.Plant()"
+ id: "Plant()"
+ parent: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ langs:
+ - "java"
+ name: "Plant()"
+ nameWithType: "Herbivorous.Plant.Plant()"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant.Plant()"
+ overload: "com.microsoft.samples.commentinheritance.Herbivorous.Plant.Plant*"
+ type: "Constructor"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public Plant()"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant.Plant*"
+ name: "Plant"
+ nameWithType: "Herbivorous.Plant.Plant"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant.Plant"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.Object.notify()"
+ name: "Object.notify()"
+ nameWithType: "Object.notify()"
+ fullName: "java.lang.Object.notify()"
+- uid: "java.lang.Object.wait()"
+ name: "Object.wait()"
+ nameWithType: "Object.wait()"
+ fullName: "java.lang.Object.wait()"
+- uid: "java.lang.Object.finalize()"
+ name: "Object.finalize()"
+ nameWithType: "Object.finalize()"
+ fullName: "java.lang.Object.finalize()"
+- uid: "java.lang.Object.clone()"
+ name: "Object.clone()"
+ nameWithType: "Object.clone()"
+ fullName: "java.lang.Object.clone()"
+- uid: "java.lang.Object.notifyAll()"
+ name: "Object.notifyAll()"
+ nameWithType: "Object.notifyAll()"
+ fullName: "java.lang.Object.notifyAll()"
+- uid: "java.lang.Object.equals(java.lang.Object)"
+ name: "Object.equals(Object)"
+ nameWithType: "Object.equals(Object)"
+ fullName: "java.lang.Object.equals(java.lang.Object)"
+- uid: "java.lang.Object.getClass()"
+ name: "Object.getClass()"
+ nameWithType: "Object.getClass()"
+ fullName: "java.lang.Object.getClass()"
+- uid: "java.lang.Object.wait(long)"
+ name: "Object.wait(long)"
+ nameWithType: "Object.wait(long)"
+ fullName: "java.lang.Object.wait(long)"
+- uid: "java.lang.Object.hashCode()"
+ name: "Object.hashCode()"
+ nameWithType: "Object.hashCode()"
+ fullName: "java.lang.Object.hashCode()"
+- uid: "java.lang.Object.wait(long,int)"
+ name: "Object.wait(long,int)"
+ nameWithType: "Object.wait(long,int)"
+ fullName: "java.lang.Object.wait(long,int)"
+- uid: "java.lang.Object.toString()"
+ name: "Object.toString()"
+ nameWithType: "Object.toString()"
+ fullName: "java.lang.Object.toString()"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.yml
new file mode 100644
index 0000000..4c84584
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Herbivorous.yml
@@ -0,0 +1,73 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous"
+ id: "Herbivorous"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ - "com.microsoft.samples.commentinheritance.Herbivorous.eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ - "com.microsoft.samples.commentinheritance.Herbivorous.getKind()"
+ langs:
+ - "java"
+ name: "Herbivorous"
+ nameWithType: "Herbivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous"
+ type: "Interface"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Marks animals that eat plants."
+ syntax:
+ content: "public interface Herbivorous"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ id: "eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ parent: "com.microsoft.samples.commentinheritance.Herbivorous"
+ langs:
+ - "java"
+ name: "eat(Herbivorous.Plant plantToBeEaten)"
+ nameWithType: "Herbivorous.eat(Herbivorous.Plant plantToBeEaten)"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.eat(Herbivorous.Plant plantToBeEaten)"
+ overload: "com.microsoft.samples.commentinheritance.Herbivorous.eat*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eat the provided plant."
+ syntax:
+ content: "public abstract void eat(Herbivorous.Plant plantToBeEaten)"
+ parameters:
+ - id: "plantToBeEaten"
+ type: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ description: "Plant that will be eaten."
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Herbivorous"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Herbivorous.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Herbivorous.getKind*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Herbivorous."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ name: "Herbivorous.Plant"
+ nameWithType: "Herbivorous.Plant"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.eat*"
+ name: "eat"
+ nameWithType: "Herbivorous.eat"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.eat"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.getKind*"
+ name: "getKind"
+ nameWithType: "Herbivorous.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.getKind"
+ package: "com.microsoft.samples.commentinheritance"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Mammal.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Mammal.yml
new file mode 100644
index 0000000..22689cd
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Mammal.yml
@@ -0,0 +1,147 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Mammal"
+ id: "Mammal"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Mammal.Mammal()"
+ - "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+ langs:
+ - "java"
+ name: "Mammal"
+ nameWithType: "Mammal"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal"
+ type: "Class"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Mammal."
+ syntax:
+ content: "public abstract class Mammal extends Animal"
+ inheritance:
+ - "java.lang.Object"
+ - "com.microsoft.samples.commentinheritance.Animal"
+ inheritedMembers:
+ - "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ - "com.microsoft.samples.commentinheritance.Animal.feed()"
+ - "com.microsoft.samples.commentinheritance.Animal.getKind()"
+ - "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ - "java.lang.Object.clone()"
+ - "java.lang.Object.equals(java.lang.Object)"
+ - "java.lang.Object.finalize()"
+ - "java.lang.Object.getClass()"
+ - "java.lang.Object.hashCode()"
+ - "java.lang.Object.notify()"
+ - "java.lang.Object.notifyAll()"
+ - "java.lang.Object.toString()"
+ - "java.lang.Object.wait()"
+ - "java.lang.Object.wait(long)"
+ - "java.lang.Object.wait(long,int)"
+- uid: "com.microsoft.samples.commentinheritance.Mammal.Mammal()"
+ id: "Mammal()"
+ parent: "com.microsoft.samples.commentinheritance.Mammal"
+ langs:
+ - "java"
+ name: "Mammal()"
+ nameWithType: "Mammal.Mammal()"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal.Mammal()"
+ overload: "com.microsoft.samples.commentinheritance.Mammal.Mammal*"
+ type: "Constructor"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public Mammal()"
+- uid: "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Mammal"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Mammal.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Mammal.getKind*"
+ overridden: "com.microsoft.samples.commentinheritance.Animal.getKind()"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Organism. Get kind from Animal. Get kind from Mammal."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Mammal.Mammal*"
+ name: "Mammal"
+ nameWithType: "Mammal.Mammal"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal.Mammal"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Mammal.getKind*"
+ name: "getKind"
+ nameWithType: "Mammal.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal.getKind"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Animal"
+ name: "Animal"
+ nameWithType: "Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal"
+- uid: "java.lang.Object.notify()"
+ name: "Object.notify()"
+ nameWithType: "Object.notify()"
+ fullName: "java.lang.Object.notify()"
+- uid: "java.lang.Object.wait()"
+ name: "Object.wait()"
+ nameWithType: "Object.wait()"
+ fullName: "java.lang.Object.wait()"
+- uid: "java.lang.Object.finalize()"
+ name: "Object.finalize()"
+ nameWithType: "Object.finalize()"
+ fullName: "java.lang.Object.finalize()"
+- uid: "java.lang.Object.notifyAll()"
+ name: "Object.notifyAll()"
+ nameWithType: "Object.notifyAll()"
+ fullName: "java.lang.Object.notifyAll()"
+- uid: "java.lang.Object.clone()"
+ name: "Object.clone()"
+ nameWithType: "Object.clone()"
+ fullName: "java.lang.Object.clone()"
+- uid: "java.lang.Object.equals(java.lang.Object)"
+ name: "Object.equals(Object)"
+ nameWithType: "Object.equals(Object)"
+ fullName: "java.lang.Object.equals(java.lang.Object)"
+- uid: "com.microsoft.samples.commentinheritance.Animal.breathe()"
+ name: "Animal.breathe()"
+ nameWithType: "Animal.breathe()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.breathe()"
+- uid: "java.lang.Object.toString()"
+ name: "Object.toString()"
+ nameWithType: "Object.toString()"
+ fullName: "java.lang.Object.toString()"
+- uid: "java.lang.Object.getClass()"
+ name: "Object.getClass()"
+ nameWithType: "Object.getClass()"
+ fullName: "java.lang.Object.getClass()"
+- uid: "java.lang.Object.wait(long)"
+ name: "Object.wait(long)"
+ nameWithType: "Object.wait(long)"
+ fullName: "java.lang.Object.wait(long)"
+- uid: "java.lang.Object.hashCode()"
+ name: "Object.hashCode()"
+ nameWithType: "Object.hashCode()"
+ fullName: "java.lang.Object.hashCode()"
+- uid: "com.microsoft.samples.commentinheritance.Animal.getKind()"
+ name: "Animal.getKind()"
+ nameWithType: "Animal.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.getKind()"
+- uid: "java.lang.Object.wait(long,int)"
+ name: "Object.wait(long,int)"
+ nameWithType: "Object.wait(long,int)"
+ fullName: "java.lang.Object.wait(long,int)"
+- uid: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+ name: "Animal.verballyCommunicate()"
+ nameWithType: "Animal.verballyCommunicate()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.verballyCommunicate()"
+- uid: "com.microsoft.samples.commentinheritance.Animal.feed()"
+ name: "Animal.feed()"
+ nameWithType: "Animal.feed()"
+ fullName: "com.microsoft.samples.commentinheritance.Animal.feed()"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Omnivorous.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Omnivorous.yml
new file mode 100644
index 0000000..7995ebf
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Omnivorous.yml
@@ -0,0 +1,104 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous"
+ id: "Omnivorous"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Omnivorous.eat(com.microsoft.samples.commentinheritance.Animal)"
+ - "com.microsoft.samples.commentinheritance.Omnivorous.eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ - "com.microsoft.samples.commentinheritance.Omnivorous.getKind()"
+ langs:
+ - "java"
+ name: "Omnivorous"
+ nameWithType: "Omnivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous"
+ type: "Interface"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eats plants and animals."
+ syntax:
+ content: "public interface Omnivorous extends Carnivorous, Herbivorous"
+ implements:
+ - "com.microsoft.samples.commentinheritance.Carnivorous"
+ - "com.microsoft.samples.commentinheritance.Herbivorous"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous.eat(com.microsoft.samples.commentinheritance.Animal)"
+ id: "eat(com.microsoft.samples.commentinheritance.Animal)"
+ parent: "com.microsoft.samples.commentinheritance.Omnivorous"
+ langs:
+ - "java"
+ name: "eat(Animal animalToBeEaten)"
+ nameWithType: "Omnivorous.eat(Animal animalToBeEaten)"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous.eat(Animal animalToBeEaten)"
+ overload: "com.microsoft.samples.commentinheritance.Omnivorous.eat*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eat the provided animal."
+ syntax:
+ content: "public abstract void eat(Animal animalToBeEaten)"
+ parameters:
+ - id: "animalToBeEaten"
+ type: "com.microsoft.samples.commentinheritance.Animal"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous.eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ id: "eat(com.microsoft.samples.commentinheritance.Herbivorous.Plant)"
+ parent: "com.microsoft.samples.commentinheritance.Omnivorous"
+ langs:
+ - "java"
+ name: "eat(Herbivorous.Plant plantToBeEaten)"
+ nameWithType: "Omnivorous.eat(Herbivorous.Plant plantToBeEaten)"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous.eat(Herbivorous.Plant plantToBeEaten)"
+ overload: "com.microsoft.samples.commentinheritance.Omnivorous.eat*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Eat the provided plant."
+ syntax:
+ content: "public abstract void eat(Herbivorous.Plant plantToBeEaten)"
+ parameters:
+ - id: "plantToBeEaten"
+ type: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Omnivorous"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Omnivorous.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Omnivorous.getKind*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Carnivorous. Get kind from Omnivorous."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Animal"
+ name: "Animal"
+ nameWithType: "Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous.eat*"
+ name: "eat"
+ nameWithType: "Omnivorous.eat"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous.eat"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ name: "Herbivorous.Plant"
+ nameWithType: "Herbivorous.Plant"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous.getKind*"
+ name: "getKind"
+ nameWithType: "Omnivorous.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous.getKind"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous"
+ name: "Herbivorous"
+ nameWithType: "Herbivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous"
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous"
+ name: "Carnivorous"
+ nameWithType: "Carnivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Organism.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Organism.yml
new file mode 100644
index 0000000..fc7597c
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Organism.yml
@@ -0,0 +1,43 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Organism"
+ id: "Organism"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Organism.getKind()"
+ langs:
+ - "java"
+ name: "Organism"
+ nameWithType: "Organism"
+ fullName: "com.microsoft.samples.commentinheritance.Organism"
+ type: "Interface"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public interface Organism"
+- uid: "com.microsoft.samples.commentinheritance.Organism.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Organism"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Organism.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Organism.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Organism.getKind*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Organism."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+references:
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Organism.getKind*"
+ name: "getKind"
+ nameWithType: "Organism.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Organism.getKind"
+ package: "com.microsoft.samples.commentinheritance"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Viviparous.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Viviparous.yml
new file mode 100644
index 0000000..d56df7c
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.Viviparous.yml
@@ -0,0 +1,71 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance.Viviparous"
+ id: "Viviparous"
+ parent: "com.microsoft.samples.commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Viviparous.getKind()"
+ - "com.microsoft.samples.commentinheritance.Viviparous.giveBirth(int)"
+ langs:
+ - "java"
+ name: "Viviparous"
+ nameWithType: "Viviparous"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous"
+ type: "Interface"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Mammals that give birth to young that develop within the mother's body."
+ syntax:
+ content: "public interface Viviparous"
+- uid: "com.microsoft.samples.commentinheritance.Viviparous.getKind()"
+ id: "getKind()"
+ parent: "com.microsoft.samples.commentinheritance.Viviparous"
+ langs:
+ - "java"
+ name: "getKind()"
+ nameWithType: "Viviparous.getKind()"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous.getKind()"
+ overload: "com.microsoft.samples.commentinheritance.Viviparous.getKind*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ summary: "Get kind from Viviparous."
+ syntax:
+ content: "public abstract String getKind()"
+ return:
+ type: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Viviparous.giveBirth(int)"
+ id: "giveBirth(int)"
+ parent: "com.microsoft.samples.commentinheritance.Viviparous"
+ langs:
+ - "java"
+ name: "giveBirth(int numberOfOffspring)"
+ nameWithType: "Viviparous.giveBirth(int numberOfOffspring)"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous.giveBirth(int numberOfOffspring)"
+ overload: "com.microsoft.samples.commentinheritance.Viviparous.giveBirth*"
+ type: "Method"
+ package: "com.microsoft.samples.commentinheritance"
+ syntax:
+ content: "public abstract void giveBirth(int numberOfOffspring)"
+ parameters:
+ - id: "numberOfOffspring"
+ type: "int"
+references:
+- uid: "int"
+ spec.java:
+ - uid: "int"
+ name: "int"
+ fullName: "int"
+- uid: "com.microsoft.samples.commentinheritance.Viviparous.giveBirth*"
+ name: "giveBirth"
+ nameWithType: "Viviparous.giveBirth"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous.giveBirth"
+ package: "com.microsoft.samples.commentinheritance"
+- uid: "java.lang.String"
+ spec.java:
+ - uid: "java.lang.String"
+ name: "String"
+ fullName: "java.lang.String"
+- uid: "com.microsoft.samples.commentinheritance.Viviparous.getKind*"
+ name: "getKind"
+ nameWithType: "Viviparous.getKind"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous.getKind"
+ package: "com.microsoft.samples.commentinheritance"
diff --git a/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.yml b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.yml
new file mode 100644
index 0000000..5842c9d
--- /dev/null
+++ b/src/test/resources/expected-generated-files/com.microsoft.samples.commentinheritance.yml
@@ -0,0 +1,59 @@
+### YamlMime:ManagedReference
+items:
+- uid: "com.microsoft.samples.commentinheritance"
+ id: "commentinheritance"
+ children:
+ - "com.microsoft.samples.commentinheritance.Animal"
+ - "com.microsoft.samples.commentinheritance.Carnivorous"
+ - "com.microsoft.samples.commentinheritance.Dog"
+ - "com.microsoft.samples.commentinheritance.Herbivorous"
+ - "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ - "com.microsoft.samples.commentinheritance.Mammal"
+ - "com.microsoft.samples.commentinheritance.Omnivorous"
+ - "com.microsoft.samples.commentinheritance.Organism"
+ - "com.microsoft.samples.commentinheritance.Viviparous"
+ langs:
+ - "java"
+ name: "com.microsoft.samples.commentinheritance"
+ nameWithType: "com.microsoft.samples.commentinheritance"
+ fullName: "com.microsoft.samples.commentinheritance"
+ type: "Namespace"
+ syntax:
+ content: "package com.microsoft.samples.commentinheritance"
+references:
+- uid: "com.microsoft.samples.commentinheritance.Animal"
+ name: "Animal"
+ nameWithType: "Animal"
+ fullName: "com.microsoft.samples.commentinheritance.Animal"
+- uid: "com.microsoft.samples.commentinheritance.Carnivorous"
+ name: "Carnivorous"
+ nameWithType: "Carnivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Carnivorous"
+- uid: "com.microsoft.samples.commentinheritance.Dog"
+ name: "Dog"
+ nameWithType: "Dog"
+ fullName: "com.microsoft.samples.commentinheritance.Dog"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous"
+ name: "Herbivorous"
+ nameWithType: "Herbivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous"
+- uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ name: "Herbivorous.Plant"
+ nameWithType: "Herbivorous.Plant"
+ fullName: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+- uid: "com.microsoft.samples.commentinheritance.Mammal"
+ name: "Mammal"
+ nameWithType: "Mammal"
+ fullName: "com.microsoft.samples.commentinheritance.Mammal"
+- uid: "com.microsoft.samples.commentinheritance.Omnivorous"
+ name: "Omnivorous"
+ nameWithType: "Omnivorous"
+ fullName: "com.microsoft.samples.commentinheritance.Omnivorous"
+- uid: "com.microsoft.samples.commentinheritance.Organism"
+ name: "Organism"
+ nameWithType: "Organism"
+ fullName: "com.microsoft.samples.commentinheritance.Organism"
+- uid: "com.microsoft.samples.commentinheritance.Viviparous"
+ name: "Viviparous"
+ nameWithType: "Viviparous"
+ fullName: "com.microsoft.samples.commentinheritance.Viviparous"
diff --git a/src/test/resources/expected-generated-files/toc.yml b/src/test/resources/expected-generated-files/toc.yml
index 8d40a83..a4e2eff 100644
--- a/src/test/resources/expected-generated-files/toc.yml
+++ b/src/test/resources/expected-generated-files/toc.yml
@@ -10,6 +10,27 @@
name: "IAgreementDetailsCollection"
- uid: "com.microsoft.samples.agreements.ResourceCollection"
name: "ResourceCollection"
+- uid: "com.microsoft.samples.commentinheritance"
+ name: "com.microsoft.samples.commentinheritance"
+ items:
+ - uid: "com.microsoft.samples.commentinheritance.Animal"
+ name: "Animal"
+ - uid: "com.microsoft.samples.commentinheritance.Carnivorous"
+ name: "Carnivorous"
+ - uid: "com.microsoft.samples.commentinheritance.Dog"
+ name: "Dog"
+ - uid: "com.microsoft.samples.commentinheritance.Herbivorous"
+ name: "Herbivorous"
+ - uid: "com.microsoft.samples.commentinheritance.Herbivorous.Plant"
+ name: "Herbivorous.Plant"
+ - uid: "com.microsoft.samples.commentinheritance.Mammal"
+ name: "Mammal"
+ - uid: "com.microsoft.samples.commentinheritance.Omnivorous"
+ name: "Omnivorous"
+ - uid: "com.microsoft.samples.commentinheritance.Organism"
+ name: "Organism"
+ - uid: "com.microsoft.samples.commentinheritance.Viviparous"
+ name: "Viviparous"
- uid: "com.microsoft.samples.offers"
name: "com.microsoft.samples.offers"
items: