/*
* JavaInspect - Utility to visualize java software
* Copyright (C) 2013-2015, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu
- *
+ *
* This program is free software; you can redistribute it and/or
* modify it under the terms of version 3 of the GNU Lesser General Public License
* or later as published by the Free Software Foundation.
import java.util.ArrayList;
import java.util.List;
+/**
+ * This class corresponds to single method within a java class.
+ */
public class MethodDescriptor implements GraphElement,
Comparable<MethodDescriptor> {
- /**
- * This class corresponds to single method within a java class.
- */
-
- public String methodName;
- public ClassDescriptor returnType;
+ private final String methodName;
+ private ClassDescriptor returnType;
private final ClassDescriptor parentClass;
+ private final List<ClassDescriptor> argumentTypes = new ArrayList<ClassDescriptor>();
+ private boolean isInherited;
- List<ClassDescriptor> argumentTypes = new ArrayList<ClassDescriptor>();
-
- public MethodDescriptor(final Method method, final ClassDescriptor parent,
- final ClassGraph dump) {
-
+ public MethodDescriptor(final ClassDescriptor parent,
+ final String methodName) {
parentClass = parent;
+ this.methodName = methodName;
+ }
- methodName = method.getName();
+ public void analyze(final Method method) {
if (!method.getDeclaringClass().getName()
- .equals(parent.classFullyQualifiedName))
- // do not index inherited methods
- return;
-
- parent.methods.add(this);
+ .equals(parentClass.getFullyQualifiedName()))
+ isInherited = true;
- returnType = dump.addClass(method.getReturnType());
+ returnType = parentClass.getClassGraph().getOrCreateClassDescriptor(
+ method.getReturnType());
returnType.registerReference();
final Type genericType = method.getGenericReturnType();
for (final Type t : pt.getActualTypeArguments())
if (t instanceof Class) {
final Class cl = (Class) t;
- final ClassDescriptor classDescriptor = dump.addClass(cl);
+ final ClassDescriptor classDescriptor = parentClass
+ .getClassGraph().getOrCreateClassDescriptor(cl);
classDescriptor.registerReference();
argumentTypes.add(classDescriptor);
}
if (classDescriptor.isVisible())
if (classDescriptor.areReferencesShown())
result.append(" " + getGraphId() + " -> "
- + classDescriptor.getGraphId() + "[label=\"" + methodName
- + "\", color=\"" + classDescriptor.getColor()
+ + classDescriptor.getGraphId() + "[label=\""
+ + methodName + "\", color=\""
+ + classDescriptor.getColor()
+ "\", style=\"dotted, bold\"];\n");
if (!returnType.isVisible())
// main type
if (returnType.areReferencesShown())
result.append(" " + getGraphId() + " -> "
- + returnType.getGraphId() + "[label=\"" + methodName + "\","
- + " color=\"" + returnType.getColor()
+ + returnType.getGraphId() + "[label=\"" + methodName
+ + "\"," + " color=\"" + returnType.getColor()
+ "\", style=\"dotted, bold\"];\n");
return result.toString();
return parentClass.getGraphId() + ":" + methodName;
}
- public String getMethodLabel() {
+ private String getMethodLabel() {
return methodName;
}
- public int getOutsideVisibleReferencesCount() {
+ protected int getOutsideVisibleReferencesCount() {
int result = 0;
if (returnType.isVisible())
@Override
public boolean isVisible() {
+ // hide inherited methods
+ if (isInherited)
+ return false;
+
// hide common object methods
if (Utils.isCommonObjectMethod(methodName))
return false;
// hide is methods for the boolean field of the same name
if (methodName.startsWith("is")) {
- final FieldDescriptor field = parentClass.getFieldIgnoreCase(methodName
- .substring(2));
+ final FieldDescriptor field = parentClass
+ .getFieldIgnoreCase(methodName.substring(2));
if (field != null)
- if ("boolean".equals(field.getType().classFullyQualifiedName))
+ if ("boolean".equals(field.getType().getFullyQualifiedName()))
return false;
}