X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fnetconf%2Fconfig-netconf-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fnetconf%2Fconfignetconfconnector%2Fmapping%2Fattributes%2FAttributeIfcSwitchStatement.java;h=cf0e71e67a52ab9983b5a2599519cf9f3014118c;hb=90c298fda86e8fa0df47a356e87cb34a20347beb;hp=1ef2ae375e723f3fb49e4890c3b0a1f1022e8d44;hpb=4f623c74a703a31e787387b536981dcb344ca4f9;p=controller.git diff --git a/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/attributes/AttributeIfcSwitchStatement.java b/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/attributes/AttributeIfcSwitchStatement.java index 1ef2ae375e..cf0e71e67a 100644 --- a/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/attributes/AttributeIfcSwitchStatement.java +++ b/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/attributes/AttributeIfcSwitchStatement.java @@ -12,30 +12,92 @@ import org.opendaylight.controller.config.yangjmxgenerator.attribute.AttributeIf import org.opendaylight.controller.config.yangjmxgenerator.attribute.DependencyAttribute; import org.opendaylight.controller.config.yangjmxgenerator.attribute.JavaAttribute; import org.opendaylight.controller.config.yangjmxgenerator.attribute.ListAttribute; +import org.opendaylight.controller.config.yangjmxgenerator.attribute.ListDependenciesAttribute; import org.opendaylight.controller.config.yangjmxgenerator.attribute.TOAttribute; +import org.opendaylight.yangtools.yang.model.api.type.BinaryTypeDefinition; + +import javax.management.openmbean.ArrayType; +import javax.management.openmbean.CompositeType; +import javax.management.openmbean.OpenType; +import javax.management.openmbean.SimpleType; public abstract class AttributeIfcSwitchStatement { + protected AttributeIfc lastAttribute; + public T switchAttribute(AttributeIfc attributeIfc) { + this.lastAttribute = attributeIfc; + + OpenType openType = attributeIfc.getOpenType(); + if (attributeIfc instanceof JavaAttribute) { - return caseJavaAttribute((JavaAttribute) attributeIfc); + try { + if(((JavaAttribute)attributeIfc).getTypeDefinition() instanceof BinaryTypeDefinition) { + return caseJavaBinaryAttribute(openType); + } else if(((JavaAttribute)attributeIfc).isUnion()) { + return caseJavaUnionAttribute(openType); + } else + return caseJavaAttribute(openType); + } catch (UnknownOpenTypeException e) { + throw getIllegalArgumentException(attributeIfc); + } + } else if (attributeIfc instanceof DependencyAttribute) { - return caseDependencyAttribute((DependencyAttribute) attributeIfc); + return caseDependencyAttribute(((DependencyAttribute) attributeIfc).getOpenType()); } else if (attributeIfc instanceof ListAttribute) { - return caseListAttribute((ListAttribute) attributeIfc); + return caseListAttribute((ArrayType) openType); + } else if (attributeIfc instanceof ListDependenciesAttribute) { + return caseListDependeciesAttribute((ArrayType) openType); } else if (attributeIfc instanceof TOAttribute) { - return caseTOAttribute((TOAttribute) attributeIfc); + return caseTOAttribute(((TOAttribute) attributeIfc).getOpenType()); } - throw new IllegalArgumentException("Unknown attribute type " + attributeIfc.getClass() + ", " + attributeIfc); + throw getIllegalArgumentException(attributeIfc); } - protected abstract T caseJavaAttribute(JavaAttribute attributeIfc); + protected T caseJavaUnionAttribute(OpenType openType) { + return caseJavaAttribute(openType); + } - protected abstract T caseDependencyAttribute(DependencyAttribute attributeIfc); + protected T caseJavaBinaryAttribute(OpenType openType) { + return caseJavaAttribute(openType); + } - protected abstract T caseTOAttribute(TOAttribute attributeIfc); + private IllegalArgumentException getIllegalArgumentException(AttributeIfc attributeIfc) { + return new IllegalArgumentException("Unknown attribute type " + attributeIfc.getClass() + ", " + attributeIfc + + " with open type:" + attributeIfc.getOpenType()); + } - protected abstract T caseListAttribute(ListAttribute attributeIfc); + public final T caseJavaAttribute(OpenType openType) { + if (openType instanceof SimpleType) { + return caseJavaSimpleAttribute((SimpleType) openType); + } else if (openType instanceof ArrayType) { + return caseJavaArrayAttribute((ArrayType) openType); + } else if (openType instanceof CompositeType) { + return caseJavaCompositeAttribute((CompositeType) openType); + } + + throw new UnknownOpenTypeException("Unknown attribute open type " + openType); + } + + protected abstract T caseJavaSimpleAttribute(SimpleType openType); + + protected abstract T caseJavaArrayAttribute(ArrayType openType); + + protected abstract T caseJavaCompositeAttribute(CompositeType openType); + + protected abstract T caseDependencyAttribute(SimpleType attributeIfc); + + protected abstract T caseTOAttribute(CompositeType openType); + + protected abstract T caseListAttribute(ArrayType openType); + + protected abstract T caseListDependeciesAttribute(ArrayType openType); + + private static class UnknownOpenTypeException extends RuntimeException { + public UnknownOpenTypeException(String message) { + super(message); + } + } }