2 * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.mdsal.binding.java.api.generator
10 import static org.opendaylight.mdsal.binding.model.ri.BaseYangTypes.BINARY_TYPE
11 import static org.opendaylight.mdsal.binding.model.ri.BaseYangTypes.BOOLEAN_TYPE
12 import static org.opendaylight.mdsal.binding.model.ri.BaseYangTypes.EMPTY_TYPE
13 import static org.opendaylight.mdsal.binding.model.ri.BaseYangTypes.STRING_TYPE
14 import static org.opendaylight.mdsal.binding.model.ri.Types.STRING
15 import static org.opendaylight.mdsal.binding.model.ri.Types.getOuterClassName
16 import static org.opendaylight.yangtools.yang.binding.contract.Naming.BINDING_CONTRACT_IMPLEMENTED_INTERFACE_NAME
17 import static org.opendaylight.yangtools.yang.binding.contract.Naming.BUILDER_SUFFIX
18 import static extension org.opendaylight.mdsal.binding.model.ri.BindingTypes.isBitsType
19 import static extension org.opendaylight.mdsal.binding.model.ri.BindingTypes.isIdentityType
21 import java.util.Base64;
22 import org.opendaylight.mdsal.binding.model.api.Enumeration
23 import org.opendaylight.mdsal.binding.model.api.GeneratedTransferObject
24 import org.opendaylight.mdsal.binding.model.api.Type
27 * Template for generating JAVA class.
29 class UnionTemplate extends ClassTemplate {
31 * Creates instance of this class with concrete <code>genType</code>.
33 * @param genType generated transfer object which will be transformed to JAVA class source code
35 new(NestedJavaGeneratedType javaType, GeneratedTransferObject genType) {
36 super(javaType, genType)
40 * Creates instance of this class with concrete <code>genType</code>.
42 * @param genType generated transfer object which will be transformed to JAVA class source code
44 new(GeneratedTransferObject genType) {
48 override constructors() '''
49 «unionConstructorsParentProperties»
51 «IF !allProperties.empty»
54 «IF properties.empty && !parentProperties.empty»
61 private def unionConstructors() '''
62 «FOR property : finalProperties SEPARATOR "\n"»
63 «val actualType = property.returnType»
64 «val restrictions = restrictionsForSetter(actualType)»
65 «IF restrictions !== null»
66 «generateCheckers(property, restrictions, actualType)»
68 «val propertyAndTopParentProperties = parentProperties + #[property]»
69 «val propFieldName = property.fieldName»
70 public «type.name»(«propertyAndTopParentProperties.asArgumentsDeclaration») {
71 «IF !parentProperties.empty»
72 super(«parentProperties.asArguments»);
74 «IF restrictions !== null»
75 «checkArgument(property, restrictions, actualType, propFieldName)»
77 «FOR other : finalProperties»
78 «IF property.equals(other)»
79 this.«propFieldName» = «JU_OBJECTS.importedName».requireNonNull(«propFieldName»);
81 this.«other.fieldName» = null;
89 val outerCls = getOuterClassName(type);
90 if (outerCls !== null) {
91 return outerCls + type.name + BUILDER_SUFFIX
93 return type.name + BUILDER_SUFFIX
96 private def unionConstructorsParentProperties() '''
97 «FOR property : parentProperties SEPARATOR "\n"»
98 public «type.name»(«property.returnType.importedName» «property.fieldName») {
99 super(«property.fieldName»);
104 def generateStringValue()
107 * Return a String representing the value of this union.
109 * @return String representation of this union's value.
111 public «STRING.importedName» stringValue() {
112 «FOR property : finalProperties»
113 «val field = property.fieldName»
114 if («field» != null) {
115 «val propRet = property.returnType»
116 «IF STRING_TYPE.equals(propRet)»
119 «ELSEIF "org.opendaylight.yangtools.yang.binding.InstanceIdentifier".equals(propRet.fullyQualifiedName)»
120 ««« type instance-identifier
121 return «field».toString();
122 «ELSEIF BINARY_TYPE.equals(propRet)»
124 return new «STRING.importedName»(«field»);
125 «ELSEIF propRet.fullyQualifiedName.startsWith("java.lang") || propRet instanceof Enumeration»
126 ««« type int* or enumeration*
127 return «field».toString();
128 «ELSEIF "org.opendaylight.yangtools.yang.common".equals(propRet.packageName)
129 && (propRet.name.startsWith("Uint") || "Decimal64".equals(propRet.name))»
130 ««« type uint*, decimal64
131 return «field».toCanonicalString();
132 «ELSEIF propRet instanceof GeneratedTransferObject && (propRet as GeneratedTransferObject).unionType»
134 return «field».stringValue();
135 «ELSEIF BOOLEAN_TYPE.equals(propRet.typedefReturnType)»
136 ««« generated boolean typedef
137 return «field».isValue().toString();
138 «ELSEIF BINARY_TYPE.equals(propRet.typedefReturnType)»
139 ««« generated byte[] typedef
140 return «Base64.importedName».getEncoder().encodeToString(«field».getValue());
141 «ELSEIF EMPTY_TYPE.equals(propRet) || EMPTY_TYPE.equals(propRet.typedefReturnType)»
142 ««« generated empty typedef
144 «ELSEIF propRet.isBitsType»
145 ««« generated bits typedef
146 return «JU_ARRAYS.importedName».toString(«field».values());
147 «ELSEIF propRet.isIdentityType»
148 ««« generated identity
149 return «field».«BINDING_CONTRACT_IMPLEMENTED_INTERFACE_NAME»().toString();
152 return «field».getValue().toString();
156 throw new IllegalStateException("No value assigned");
160 private static def Type typedefReturnType(Type type) {
161 if (!(type instanceof GeneratedTransferObject)) {
164 val gto = type as GeneratedTransferObject
165 if (!gto.typedef || gto.properties === null || gto.properties.size != 1) {
168 val prop = gto.properties.get(0)
169 if (prop.name.equals("value")) {
170 return prop.returnType
175 override protected copyConstructor() '''
177 * Creates a copy from Source Object.
179 * @param source Source object
181 public «type.name»(«type.name» source) {
182 «IF !parentProperties.empty»
186 «val fieldName = p.fieldName»
187 «IF p.returnType.name.endsWith("[]")»
188 this.«fieldName» = source.«fieldName» == null ? null : source.«fieldName».clone();
190 this.«fieldName» = source.«fieldName»;