blob: 89e0667ee27c8d48d7a3398795774203e5d9406c [file] [log] [blame]
Bharat saraswal870c56f2016-02-20 21:57:16 +05301/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Bharat saraswal870c56f2016-02-20 21:57:16 +05303 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package org.onosproject.yangutils.translator.tojava.utils;
18
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053019import org.onosproject.yangutils.datamodel.YangNode;
20import org.onosproject.yangutils.translator.tojava.JavaFileInfoContainer;
21import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
22import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFilesContainer;
23import org.onosproject.yangutils.translator.tojava.javamodel.YangJavaNotification;
24
Bharat saraswale2d51d62016-03-23 19:40:35 +053025import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_CLASS_MASK;
26import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_INTERFACE_MASK;
Bharat saraswald72411a2016-04-19 01:00:16 +053027import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_ENUM_CLASS;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053028import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_CLASS;
29import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_LISTENER_INTERFACE;
30import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_SERVICE_AND_MANAGER;
Bharat saraswale2d51d62016-03-23 19:40:35 +053031import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_TYPEDEF_CLASS;
Gaurav Agrawal338735b2016-04-18 18:53:11 +053032import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_UNION_CLASS;
Bharat saraswale2d51d62016-03-23 19:40:35 +053033import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.IMPL_CLASS_MASK;
34import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.INTERFACE_MASK;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053035import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getCapitalCase;
Bharat saraswale2d51d62016-03-23 19:40:35 +053036import static org.onosproject.yangutils.utils.UtilConstants.BUILDER;
37import static org.onosproject.yangutils.utils.UtilConstants.CLASS;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053038import static org.onosproject.yangutils.utils.UtilConstants.COMMA;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053039import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_CLOSE_BRACKET;
40import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_OPEN_BRACKET;
41import static org.onosproject.yangutils.utils.UtilConstants.EIGHT_SPACE_INDENTATION;
Bharat saraswald72411a2016-04-19 01:00:16 +053042import static org.onosproject.yangutils.utils.UtilConstants.ENUM;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053043import static org.onosproject.yangutils.utils.UtilConstants.EVENT_LISTENER_STRING;
44import static org.onosproject.yangutils.utils.UtilConstants.EVENT_STRING;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053045import static org.onosproject.yangutils.utils.UtilConstants.EXTEND;
Bharat saraswale2d51d62016-03-23 19:40:35 +053046import static org.onosproject.yangutils.utils.UtilConstants.FINAL;
47import static org.onosproject.yangutils.utils.UtilConstants.IMPL;
48import static org.onosproject.yangutils.utils.UtilConstants.IMPLEMENTS;
49import static org.onosproject.yangutils.utils.UtilConstants.INTERFACE;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053050import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_REG;
51import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_SERVICE;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053052import static org.onosproject.yangutils.utils.UtilConstants.MANAGER;
Bharat saraswale2d51d62016-03-23 19:40:35 +053053import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
54import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET;
55import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
56import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053057import static org.onosproject.yangutils.utils.UtilConstants.SERVICE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053058import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053059import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.trimAtLast;
Bharat saraswal870c56f2016-02-20 21:57:16 +053060
61/**
Bharat saraswald9822e92016-04-05 15:13:44 +053062 * Represents generator for class definition of generated files.
Bharat saraswal870c56f2016-02-20 21:57:16 +053063 */
64public final class ClassDefinitionGenerator {
65
66 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053067 * Creates an instance of class definition generator.
Bharat saraswal870c56f2016-02-20 21:57:16 +053068 */
69 private ClassDefinitionGenerator() {
70 }
71
72 /**
Vinod Kumar Sc4216002016-03-03 19:55:30 +053073 * Based on the file type and the YANG name of the file, generate the class
74 * / interface definition start.
Bharat saraswal870c56f2016-02-20 21:57:16 +053075 *
76 * @param genFileTypes generated file type
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053077 * @param yangName class name
Bharat saraswal870c56f2016-02-20 21:57:16 +053078 * @return class definition
79 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +053080 public static String generateClassDefinition(int genFileTypes, String yangName) {
Bharat saraswal870c56f2016-02-20 21:57:16 +053081
82 /**
Gaurav Agrawal56527662016-04-20 15:49:17 +053083 * Based on the file type and the YANG name of the file, generate the
Vinod Kumar Sc4216002016-03-03 19:55:30 +053084 * class / interface definition start.
Bharat saraswal870c56f2016-02-20 21:57:16 +053085 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053086 switch (genFileTypes) {
87 case BUILDER_CLASS_MASK:
Bharat saraswalc0e04842016-05-12 13:16:57 +053088 return getBuilderClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053089 case IMPL_CLASS_MASK:
Bharat saraswal870c56f2016-02-20 21:57:16 +053090 return getImplClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053091 case BUILDER_INTERFACE_MASK:
Vinod Kumar Sc4216002016-03-03 19:55:30 +053092 return getBuilderInterfaceDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053093 case GENERATE_TYPEDEF_CLASS:
94 case GENERATE_UNION_CLASS:
Gaurav Agrawal338735b2016-04-18 18:53:11 +053095 return getTypeClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053096 case GENERATE_ENUM_CLASS:
Bharat saraswald72411a2016-04-19 01:00:16 +053097 return getEnumClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053098 case GENERATE_EVENT_LISTENER_INTERFACE:
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053099 return getEventListenerDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530100 default:
101 return null;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530102 }
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530103 }
104
105 /**
106 * Based on the file type and the YANG name of the file, generate the class
107 * / interface definition start.
108 *
109 * @param genFileTypes generated file type
110 * @param yangName class name
111 * @param curNode current YANG node
112 * @return class definition
113 */
114 public static String generateClassDefinition(int genFileTypes, String yangName, YangNode curNode) {
115
116 /**
117 * Based on the file type and the YANG name of the file, generate the
118 * class / interface definition start.
119 */
120 switch (genFileTypes) {
121 case INTERFACE_MASK:
122 return getInterfaceDefinition(yangName, curNode);
123 case GENERATE_SERVICE_AND_MANAGER:
124 return getRpcInterfaceDefinition(yangName, curNode);
125 case GENERATE_EVENT_CLASS:
126 String eventName = getCapitalCase(((JavaFileInfoContainer) curNode)
127 .getJavaFileInfo().getJavaName());
128 return getEventDefinition(yangName, eventName);
129 default:
130 return null;
131 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530132 }
133
134 /**
Bharat saraswald72411a2016-04-19 01:00:16 +0530135 * Returns enum file class definition.
136 *
137 * @param yangName class name
Gaurav Agrawal56527662016-04-20 15:49:17 +0530138 * @return enum file class definition
Bharat saraswald72411a2016-04-19 01:00:16 +0530139 */
140 private static String getEnumClassDefinition(String yangName) {
141 return PUBLIC + SPACE + ENUM + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
142 }
143
144 /**
Bharat saraswal870c56f2016-02-20 21:57:16 +0530145 * Returns interface file class definition.
146 *
147 * @param yangName file name
148 * @return definition
149 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530150 private static String getInterfaceDefinition(String yangName, YangNode curNode) {
151 JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode)
152 .getTempJavaCodeFragmentFiles().getBeanTempFiles().getJavaExtendsListHolder();
Bharat saraswal870c56f2016-02-20 21:57:16 +0530153
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530154 if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) {
155 String def = PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + EXTEND + SPACE;
156 for (JavaQualifiedTypeInfo info : holder.getExtendsList()) {
157 if (!holder.getExtendedClassStore().get(info)) {
158 def = def + info.getClassInfo() + COMMA + SPACE;
159 } else {
160 def = def + info.getPkgInfo() + PERIOD + info.getClassInfo() + COMMA + SPACE;
161 }
162 }
163
164 def = trimAtLast(def, COMMA);
165
166 return def + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
167 }
168 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530169 }
170
171 /**
172 * Returns builder interface file class definition.
173 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530174 * @param yangName java class name, corresponding to which the builder class
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530175 * is being generated
Bharat saraswal870c56f2016-02-20 21:57:16 +0530176 * @return definition
177 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530178 private static String getBuilderInterfaceDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530179 return INTERFACE + SPACE + yangName + BUILDER + SPACE + OPEN_CURLY_BRACKET + NEW_LINE + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530180 }
181
182 /**
183 * Returns builder file class definition.
184 *
185 * @param yangName file name
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530186 * @param genFileTypes
Bharat saraswal870c56f2016-02-20 21:57:16 +0530187 * @return definition
188 */
Bharat saraswalc0e04842016-05-12 13:16:57 +0530189 private static String getBuilderClassDefinition(String yangName) {
190 return PUBLIC + SPACE + CLASS + SPACE + yangName + BUILDER + SPACE + IMPLEMENTS + SPACE + yangName + PERIOD
191 + yangName + BUILDER + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530192 }
193
194 /**
195 * Returns impl file class definition.
196 *
197 * @param yangName file name
198 * @return definition
199 */
200 private static String getImplClassDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530201 return PUBLIC + SPACE + FINAL + SPACE + CLASS + SPACE + yangName + IMPL + SPACE + IMPLEMENTS + SPACE + yangName
202 + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530203 }
204
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530205 /**
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530206 * Returns type file class definition.
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530207 *
208 * @param yangName file name
209 * @return definition
210 */
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530211 private static String getTypeClassDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530212 return PUBLIC + SPACE + FINAL + SPACE + CLASS + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530213 }
Gaurav Agrawal56527662016-04-20 15:49:17 +0530214
215 /**
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530216 * Returns RPC file interface definition.
Gaurav Agrawal56527662016-04-20 15:49:17 +0530217 *
218 * @param yangName file name
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530219 * @param curNode current YANG node
Gaurav Agrawal56527662016-04-20 15:49:17 +0530220 * @return definition
221 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530222 private static String getRpcInterfaceDefinition(String yangName, YangNode curNode) {
223 JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode)
224 .getTempJavaCodeFragmentFiles().getServiceTempFiles().getJavaExtendsListHolder();
225 if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) {
226 curNode = curNode.getChild();
227 while (curNode != null) {
228 if (curNode instanceof YangJavaNotification) {
229 return getRpcInterfaceDefinitionWhenItExtends(yangName, holder);
230 }
231 curNode = curNode.getNextSibling();
232 }
233 }
Bharat saraswalc0e04842016-05-12 13:16:57 +0530234 if (yangName.contains(SERVICE)) {
235 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
236 }
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530237 return PUBLIC + SPACE + CLASS + SPACE + yangName + MANAGER + SPACE + IMPLEMENTS + SPACE + yangName
238 + SERVICE + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
239 }
240
241 /* Provides class definition when RPC interface needs to extends any event.*/
242 private static String getRpcInterfaceDefinitionWhenItExtends(String yangName,
243 JavaExtendsListHolder holder) {
244
245 if (yangName.contains(SERVICE)) {
246 String[] strArray = yangName.split(SERVICE);
247 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + NEW_LINE + EIGHT_SPACE_INDENTATION
248 + EXTEND + SPACE + LISTENER_SERVICE + DIAMOND_OPEN_BRACKET + strArray[0] + EVENT_STRING + COMMA
249 + SPACE + strArray[0] + EVENT_LISTENER_STRING + DIAMOND_CLOSE_BRACKET + SPACE
250 + OPEN_CURLY_BRACKET + NEW_LINE;
251 }
252 return PUBLIC + SPACE + CLASS + SPACE + yangName + MANAGER + SPACE + NEW_LINE + EIGHT_SPACE_INDENTATION
253 + EXTEND + SPACE + LISTENER_REG + DIAMOND_OPEN_BRACKET + yangName + EVENT_STRING + COMMA + SPACE
254 + yangName + EVENT_LISTENER_STRING + DIAMOND_CLOSE_BRACKET + SPACE + NEW_LINE
255 + EIGHT_SPACE_INDENTATION + IMPLEMENTS + SPACE + yangName + SERVICE + SPACE + OPEN_CURLY_BRACKET
256 + NEW_LINE;
Gaurav Agrawal56527662016-04-20 15:49:17 +0530257 }
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530258
259 /**
260 * Returns event class definition.
261 *
262 * @param javaName file name
263 * @return definition
264 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530265 private static String getEventDefinition(String javaName, String eventName) {
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530266 String classDef = PUBLIC + SPACE + CLASS + SPACE + javaName + SPACE + "extends AbstractEvent<"
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530267 + javaName + ".Type, " + eventName + ">" + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530268
269 return classDef;
270 }
271
272 /**
273 * Returns event listener interface definition.
274 *
275 * @param javaName file name
276 * @return definition
277 */
278 private static String getEventListenerDefinition(String javaName) {
279 String intfDef = PUBLIC + SPACE + INTERFACE + SPACE + javaName + SPACE + "extends EventListener<"
280 + javaName;
281 if (intfDef.length() < 8) {
282 throw new RuntimeException("Event listener interface name is error");
283 }
Bharat saraswalc0e04842016-05-12 13:16:57 +0530284 intfDef = intfDef.substring(0, intfDef.length() - 8);
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530285 intfDef = intfDef + "Event>" + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
286
287 return intfDef;
288 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530289}