import com.google.common.collect.Collections2;
import com.google.common.collect.Maps;
import com.google.common.collect.Sets;
-import org.opendaylight.controller.config.yangjmxgenerator.ModuleMXBeanEntry;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Map.Entry;
+import java.util.Set;
+import javax.management.openmbean.CompositeType;
+import javax.management.openmbean.OpenDataException;
+import javax.management.openmbean.OpenType;
import org.opendaylight.controller.config.yangjmxgenerator.TypeProviderWrapper;
+import org.opendaylight.mdsal.binding.generator.util.ReferencedTypeImpl;
+import org.opendaylight.mdsal.binding.model.api.Type;
import org.opendaylight.yangtools.yang.model.api.AugmentationTarget;
import org.opendaylight.yangtools.yang.model.api.ContainerSchemaNode;
import org.opendaylight.yangtools.yang.model.api.DataNodeContainer;
import org.opendaylight.yangtools.yang.model.api.LeafSchemaNode;
import org.opendaylight.yangtools.yang.model.api.ListSchemaNode;
-import javax.management.openmbean.CompositeType;
-import javax.management.openmbean.OpenDataException;
-import javax.management.openmbean.OpenType;
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Map.Entry;
-import java.util.Set;
-
-public class TOAttribute extends AbstractAttribute {
+public class TOAttribute extends AbstractAttribute implements TypedAttribute {
private final String nullableDescription, nullableDefault;
private final Map<String, AttributeIfc> yangNameToAttributeMap;
private final Map<String, String> attributeNameMap;
+ private final String packageName;
private static final Set<Class<? extends DataSchemaNode>> ALLOWED_CHILDREN = Sets
.newHashSet();
}
public static <T extends DataNodeContainer & AugmentationTarget & DataSchemaNode> TOAttribute create(
- T containerSchemaNode, TypeProviderWrapper typeProviderWrapper) {
+ final T containerSchemaNode, final TypeProviderWrapper typeProviderWrapper, final String packageName) {
// Transfer Object: get the leaves
- Map<String, AttributeIfc> map = new HashMap<>();
- Map<String, String> attributeNameMap = new HashMap<>();
- for (DataSchemaNode dataSchemaNode : containerSchemaNode
+ final Map<String, AttributeIfc> map = new HashMap<>();
+ final Map<String, String> attributeNameMap = new HashMap<>();
+ for (final DataSchemaNode dataSchemaNode : containerSchemaNode
.getChildNodes()) {
try {
- String yangName = dataSchemaNode.getQName().getLocalName();
+ final String yangName = dataSchemaNode.getQName().getLocalName();
map.put(yangName,
createInnerAttribute(dataSchemaNode,
- typeProviderWrapper));
- } catch (IllegalArgumentException e) {
+ typeProviderWrapper, packageName));
+ } catch (final IllegalArgumentException e) {
throw new IllegalStateException("Unable to create TO", e);
}
}
return new TOAttribute(containerSchemaNode, map, attributeNameMap,
- containerSchemaNode.getDescription());
+ containerSchemaNode.getDescription(), packageName);
}
private static AttributeIfc createInnerAttribute(
- DataSchemaNode dataSchemaNode,
- TypeProviderWrapper typeProviderWrapper) {
- Class<? extends DataSchemaNode> type = isAllowedType(dataSchemaNode);
+ final DataSchemaNode dataSchemaNode,
+ final TypeProviderWrapper typeProviderWrapper, final String packageName) {
+ final Class<? extends DataSchemaNode> type = isAllowedType(dataSchemaNode);
- if (type.equals(LeafSchemaNode.class))
+ if (type.equals(LeafSchemaNode.class)) {
return new JavaAttribute((LeafSchemaNode) dataSchemaNode,
typeProviderWrapper);
- else if (type.equals(ListSchemaNode.class))
+ } else if (type.equals(ListSchemaNode.class)) {
return ListAttribute.create((ListSchemaNode) dataSchemaNode,
- typeProviderWrapper);
- else if (type.equals(LeafListSchemaNode.class))
+ typeProviderWrapper, packageName);
+ } else if (type.equals(LeafListSchemaNode.class)) {
return ListAttribute.create((LeafListSchemaNode) dataSchemaNode,
typeProviderWrapper);
- else if (type.equals(ContainerSchemaNode.class))
+ } else if (type.equals(ContainerSchemaNode.class)) {
return TOAttribute.create((ContainerSchemaNode) dataSchemaNode,
- typeProviderWrapper);
+ typeProviderWrapper, packageName);
+ }
throw new IllegalStateException("This should never happen");
}
private static Class<? extends DataSchemaNode> isAllowedType(
- DataSchemaNode dataSchemaNode) {
- for (Class<? extends DataSchemaNode> allowedType : ALLOWED_CHILDREN) {
- if (allowedType.isAssignableFrom(dataSchemaNode.getClass()) == true)
+ final DataSchemaNode dataSchemaNode) {
+ for (final Class<? extends DataSchemaNode> allowedType : ALLOWED_CHILDREN) {
+ if (allowedType.isAssignableFrom(dataSchemaNode.getClass()) == true) {
return allowedType;
+ }
}
throw new IllegalArgumentException("Illegal child node for TO: "
+ dataSchemaNode.getClass() + " allowed node types: "
+ ALLOWED_CHILDREN);
}
- private TOAttribute(DataSchemaNode attrNode,
- Map<String, AttributeIfc> transferObject,
- Map<String, String> attributeNameMap, String nullableDescription) {
+ private TOAttribute(final DataSchemaNode attrNode,
+ final Map<String, AttributeIfc> transferObject,
+ final Map<String, String> attributeNameMap, final String nullableDescription, final String packageName) {
super(attrNode);
- yangNameToAttributeMap = transferObject;
+ this.yangNameToAttributeMap = transferObject;
this.attributeNameMap = attributeNameMap;
this.nullableDescription = nullableDescription;
- nullableDefault = null;
+ this.nullableDefault = null;
+ this.packageName = packageName;
}
public Map<String, String> getAttributeNameMap() {
- return attributeNameMap;
+ return this.attributeNameMap;
}
public Map<String, AttributeIfc> getCapitalizedPropertiesToTypesMap() {
- Map<String, AttributeIfc> capitalizedPropertiesToTypesMap = Maps
+ final Map<String, AttributeIfc> capitalizedPropertiesToTypesMap = Maps
.newHashMap();
- for (Entry<String, AttributeIfc> entry : yangNameToAttributeMap
+ for (final Entry<String, AttributeIfc> entry : this.yangNameToAttributeMap
.entrySet()) {
capitalizedPropertiesToTypesMap.put(
- ModuleMXBeanEntry.convertToJavaName(entry.getKey(), true),
+ TypeProviderWrapper.convertToJavaName(entry.getKey(), true),
entry.getValue());
}
return capitalizedPropertiesToTypesMap;
}
public Map<String, AttributeIfc> getJmxPropertiesToTypesMap() {
- Map<String, AttributeIfc> jmxPropertiesToTypesMap = Maps.newHashMap();
- for (Entry<String, AttributeIfc> entry : yangNameToAttributeMap
+ final Map<String, AttributeIfc> jmxPropertiesToTypesMap = Maps.newHashMap();
+ for (final Entry<String, AttributeIfc> entry : this.yangNameToAttributeMap
.entrySet()) {
jmxPropertiesToTypesMap.put(
- ModuleMXBeanEntry.convertToJavaName(entry.getKey(), false),
+ TypeProviderWrapper.convertToJavaName(entry.getKey(), false),
entry.getValue());
}
return jmxPropertiesToTypesMap;
}
public Map<String, AttributeIfc> getYangPropertiesToTypesMap() {
- return yangNameToAttributeMap;
+ return this.yangNameToAttributeMap;
}
@Override
public String getNullableDescription() {
- return nullableDescription;
+ return this.nullableDescription;
}
@Override
public String getNullableDefault() {
- return nullableDefault;
+ return this.nullableDefault;
}
@Override
- public boolean equals(Object o) {
- if (this == o)
+ public boolean equals(final Object o) {
+ if (this == o) {
return true;
- if (o == null || getClass() != o.getClass())
+ }
+ if ((o == null) || (getClass() != o.getClass())) {
return false;
- if (!super.equals(o))
+ }
+ if (!super.equals(o)) {
return false;
+ }
- TOAttribute that = (TOAttribute) o;
+ final TOAttribute that = (TOAttribute) o;
- if (nullableDefault != null ? !nullableDefault
- .equals(that.nullableDefault) : that.nullableDefault != null)
+ if (this.nullableDefault != null ? !this.nullableDefault
+ .equals(that.nullableDefault) : that.nullableDefault != null) {
return false;
- if (nullableDescription != null ? !nullableDescription
+ }
+ if (this.nullableDescription != null ? !this.nullableDescription
.equals(that.nullableDescription)
- : that.nullableDescription != null)
+ : that.nullableDescription != null) {
return false;
- if (yangNameToAttributeMap != null ? !yangNameToAttributeMap
+ }
+ if (this.yangNameToAttributeMap != null ? !this.yangNameToAttributeMap
.equals(that.yangNameToAttributeMap)
- : that.yangNameToAttributeMap != null)
+ : that.yangNameToAttributeMap != null) {
return false;
+ }
return true;
}
@Override
public int hashCode() {
int result = super.hashCode();
- result = 31
- * result
- + (nullableDescription != null ? nullableDescription.hashCode()
+ result = (31
+ * result)
+ + (this.nullableDescription != null ? this.nullableDescription.hashCode()
: 0);
- result = 31 * result
- + (nullableDefault != null ? nullableDefault.hashCode() : 0);
- result = 31
- * result
- + (yangNameToAttributeMap != null ? yangNameToAttributeMap
+ result = (31 * result)
+ + (this.nullableDefault != null ? this.nullableDefault.hashCode() : 0);
+ result = (31
+ * result)
+ + (this.yangNameToAttributeMap != null ? this.yangNameToAttributeMap
.hashCode() : 0);
return result;
}
@Override
public String toString() {
return "TOAttribute{" + getAttributeYangName() + "," + "to="
- + yangNameToAttributeMap + '}';
+ + this.yangNameToAttributeMap + '}';
+ }
+
+ @Override
+ public Type getType() {
+ // TODO: ReferencedTypeImpl from Types
+ return new ReferencedTypeImpl(this.packageName, getUpperCaseCammelCase());
}
@Override
public CompositeType getOpenType() {
- String description = getNullableDescription() == null ? getAttributeYangName()
- : getNullableDescription();
- final String[] itemNames = new String[yangNameToAttributeMap.keySet()
- .size()];
- String[] itemDescriptions = itemNames;
- FunctionImpl functionImpl = new FunctionImpl(itemNames);
- Map<String, AttributeIfc> jmxPropertiesToTypesMap = getJmxPropertiesToTypesMap();
- OpenType<?>[] itemTypes = Collections2.transform(
+ final String description = getNullableDescription() == null ? getAttributeYangName() : getNullableDescription();
+
+ final FunctionImpl functionImpl = new FunctionImpl();
+ final Map<String, AttributeIfc> jmxPropertiesToTypesMap = getJmxPropertiesToTypesMap();
+ final OpenType<?>[] itemTypes = Collections2.transform(
jmxPropertiesToTypesMap.entrySet(), functionImpl).toArray(
new OpenType<?>[] {});
+ final String[] itemNames = functionImpl.getItemNames();
try {
// TODO add package name to create fully qualified name for this
// type
- CompositeType compositeType = new CompositeType(
+ final CompositeType compositeType = new CompositeType(
getUpperCaseCammelCase(), description, itemNames,
- itemDescriptions, itemTypes);
+ itemNames, itemTypes);
return compositeType;
- } catch (OpenDataException e) {
+ } catch (final OpenDataException e) {
throw new RuntimeException("Unable to create CompositeType for "
+ this, e);
}
}
- private static final class FunctionImpl implements
- Function<Entry<String, AttributeIfc>, OpenType<?>> {
- private final String[] itemNames;
- int i = 0;
+ public String getPackageName() {
+ return this.packageName;
+ }
- private FunctionImpl(String[] itemNames) {
- this.itemNames = itemNames;
- }
+}
- @Override
- public OpenType<?> apply(Entry<String, AttributeIfc> input) {
- AttributeIfc innerType = input.getValue();
- itemNames[i++] = input.getKey();
- return innerType.getOpenType();
- }
+class FunctionImpl implements
+ Function<Entry<String, AttributeIfc>, OpenType<?>> {
+ private final List<String> itemNames = new ArrayList<>();
+
+ @Override
+ public OpenType<?> apply(final Entry<String, AttributeIfc> input) {
+ final AttributeIfc innerType = input.getValue();
+ this.itemNames.add(input.getKey());
+ return innerType.getOpenType();
+ }
+
+ public String[] getItemNames(){
+ return this.itemNames.toArray(new String[this.itemNames.size()]);
}
}