com.github.javaparser.metamodel.PropertyMetaModel Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of javaparser-metamodel Show documentation
Show all versions of javaparser-metamodel Show documentation
A description of all the types nodes that can appear in the AST
The newest version!
package com.github.javaparser.metamodel;
import com.github.javaparser.ast.Node;
import java.util.Optional;
import static com.github.javaparser.generator.utils.GeneratorUtils.decapitalize;
import static com.github.javaparser.generator.utils.GeneratorUtils.getterName;
import static com.github.javaparser.generator.utils.GeneratorUtils.setterName;
/**
* Meta-data about a property of a node in the AST.
*/
public class PropertyMetaModel {
private final BaseNodeMetaModel containingNodeMetaModel;
private final String name;
private final Class> type;
private final Optional nodeReference;
private final boolean isOptional;
private final boolean isNonEmpty;
private final boolean isNodeList;
private final boolean isEnumSet;
private final boolean hasWildcard;
public PropertyMetaModel(BaseNodeMetaModel containingNodeMetaModel, String name, Class> type, Optional nodeReference, boolean isOptional, boolean isNonEmpty, boolean isNodeList, boolean isEnumSet, boolean hasWildcard) {
this.containingNodeMetaModel = containingNodeMetaModel;
this.name = name;
this.type = type;
this.nodeReference = nodeReference;
this.isOptional = isOptional;
this.isNonEmpty = isNonEmpty;
this.isNodeList = isNodeList;
this.isEnumSet = isEnumSet;
this.hasWildcard = hasWildcard;
}
/**
* @return is this the field fieldName on class c?
*/
public boolean is(Class extends Node> c, String fieldName) {
return containingNodeMetaModel.is(c) && name.equals(fieldName);
}
/**
* @return is this fields called fieldName?
*/
public boolean is(String fieldName) {
return name.equals(fieldName);
}
/**
* @return the name used in the AST for the setter
*/
public String getSetterMethodName() {
return setterName(name);
}
/**
* @return the name used in the AST for the getter
*/
public String getGetterMethodName() {
return getterName(type, name);
}
/**
* @return the NodeMetaModel that "has" this property.
*/
public BaseNodeMetaModel getContainingNodeMetaModel() {
return containingNodeMetaModel;
}
/**
* @return the name of the property. This is equal to the name of the field in the AST.
*/
public String getName() {
return name;
}
/**
* @return whether this field may contain an empty String.
*/
public boolean isNonEmpty() {
return isNonEmpty;
}
/**
* @return the class of the field.
*/
public Class> getType() {
return type;
}
/**
* @return if this property is a Node, this will get the node meta model.
*/
public Optional getNodeReference() {
return nodeReference;
}
/**
* @return whether this property is optional.
*/
public boolean isOptional() {
return isOptional;
}
/**
* @return whether this property is not optional.
*/
public boolean isRequired() {
return !isOptional;
}
/**
* @return whether this property is contained in a NodeList.
*/
public boolean isNodeList() {
return isNodeList;
}
/**
* @return whether this property is contained in an EnumSet.
*/
public boolean isEnumSet() {
return isEnumSet;
}
/**
* @return whether this property has a wildcard following it, like BodyDeclaration<?>.
*/
public boolean hasWildcard() {
return hasWildcard;
}
@Override
public String toString() {
return "(" + getTypeName() + ")\t" + containingNodeMetaModel + "#" + name;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
PropertyMetaModel that = (PropertyMetaModel) o;
if (!name.equals(that.name)) return false;
if (!type.equals(that.type)) return false;
return true;
}
@Override
public int hashCode() {
int result = name.hashCode();
result = 31 * result + type.hashCode();
return result;
}
/**
* @return the type of a single element of this property, so no Optional or NodeList or EnumSet.
*/
public String getTypeNameGenerified() {
if (hasWildcard) {
return getTypeName() + ">";
}
return getTypeName();
}
/**
* @return the raw type of a single element of this property, so nothing but the name.
*/
public String getTypeName() {
return type.getSimpleName();
}
/**
* @return the type that is returned from getters in the AST.
*/
public String getTypeNameForGetter() {
if (isOptional) {
return "Optional<" + getTypeNameForSetter() + ">";
}
return getTypeNameForSetter();
}
/**
* @return the type that is passed to setters in the AST.
*/
public String getTypeNameForSetter() {
if (isNodeList) {
return "NodeList<" + getTypeNameGenerified() + ">";
}
if (isEnumSet) {
return "EnumSet<" + getTypeNameGenerified() + ">";
}
return getTypeNameGenerified();
}
/**
* @return is this property an AST Node?
*/
public boolean isNode() {
return getNodeReference().isPresent();
}
/**
* The name of the field in the containing BaseNodeMetaModel for this property meta model.
*/
public String getMetaModelFieldName() {
return getName() + "PropertyMetaModel";
}
}