blob: f0a16f61f9bde24be3c09726c7fd2dfabc706e78 [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;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053020import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
21import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFilesContainer;
22import org.onosproject.yangutils.translator.tojava.javamodel.YangJavaNotification;
23
Bharat saraswale2d51d62016-03-23 19:40:35 +053024import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_CLASS_MASK;
25import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_INTERFACE_MASK;
Bharat saraswald72411a2016-04-19 01:00:16 +053026import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_ENUM_CLASS;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053027import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_CLASS;
28import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_LISTENER_INTERFACE;
Bharat saraswal33dfa012016-05-17 19:59:16 +053029import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_SUBJECT_CLASS;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053030import 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;
35import static org.onosproject.yangutils.utils.UtilConstants.BUILDER;
36import static org.onosproject.yangutils.utils.UtilConstants.CLASS;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053037import static org.onosproject.yangutils.utils.UtilConstants.COMMA;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053038import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_CLOSE_BRACKET;
39import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_OPEN_BRACKET;
40import static org.onosproject.yangutils.utils.UtilConstants.EIGHT_SPACE_INDENTATION;
Bharat saraswald72411a2016-04-19 01:00:16 +053041import static org.onosproject.yangutils.utils.UtilConstants.ENUM;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053042import static org.onosproject.yangutils.utils.UtilConstants.EVENT_LISTENER_STRING;
43import static org.onosproject.yangutils.utils.UtilConstants.EVENT_STRING;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053044import static org.onosproject.yangutils.utils.UtilConstants.EXTEND;
Bharat saraswale2d51d62016-03-23 19:40:35 +053045import static org.onosproject.yangutils.utils.UtilConstants.FINAL;
46import static org.onosproject.yangutils.utils.UtilConstants.IMPL;
47import static org.onosproject.yangutils.utils.UtilConstants.IMPLEMENTS;
48import static org.onosproject.yangutils.utils.UtilConstants.INTERFACE;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053049import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_REG;
50import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_SERVICE;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053051import static org.onosproject.yangutils.utils.UtilConstants.MANAGER;
Bharat saraswale2d51d62016-03-23 19:40:35 +053052import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
53import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET;
54import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
55import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053056import static org.onosproject.yangutils.utils.UtilConstants.SERVICE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053057import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswal33dfa012016-05-17 19:59:16 +053058import static org.onosproject.yangutils.utils.UtilConstants.SUBJECT;
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 default:
99 return null;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530100 }
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530101 }
102
103 /**
104 * Based on the file type and the YANG name of the file, generate the class
105 * / interface definition start.
106 *
107 * @param genFileTypes generated file type
108 * @param yangName class name
109 * @param curNode current YANG node
110 * @return class definition
111 */
112 public static String generateClassDefinition(int genFileTypes, String yangName, YangNode curNode) {
113
114 /**
115 * Based on the file type and the YANG name of the file, generate the
116 * class / interface definition start.
117 */
118 switch (genFileTypes) {
119 case INTERFACE_MASK:
120 return getInterfaceDefinition(yangName, curNode);
121 case GENERATE_SERVICE_AND_MANAGER:
122 return getRpcInterfaceDefinition(yangName, curNode);
123 case GENERATE_EVENT_CLASS:
Bharat saraswal33dfa012016-05-17 19:59:16 +0530124 String eventName = yangName + SUBJECT;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530125 return getEventDefinition(yangName, eventName);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530126 case GENERATE_EVENT_LISTENER_INTERFACE:
127 return getEventListenerDefinition(yangName);
128 case GENERATE_EVENT_SUBJECT_CLASS:
129 return getClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530130 default:
131 return null;
132 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530133 }
134
135 /**
Bharat saraswald72411a2016-04-19 01:00:16 +0530136 * Returns enum file class definition.
137 *
138 * @param yangName class name
Gaurav Agrawal56527662016-04-20 15:49:17 +0530139 * @return enum file class definition
Bharat saraswald72411a2016-04-19 01:00:16 +0530140 */
141 private static String getEnumClassDefinition(String yangName) {
142 return PUBLIC + SPACE + ENUM + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
143 }
144
145 /**
Bharat saraswal870c56f2016-02-20 21:57:16 +0530146 * Returns interface file class definition.
147 *
148 * @param yangName file name
149 * @return definition
150 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530151 private static String getInterfaceDefinition(String yangName, YangNode curNode) {
152 JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode)
153 .getTempJavaCodeFragmentFiles().getBeanTempFiles().getJavaExtendsListHolder();
Bharat saraswal870c56f2016-02-20 21:57:16 +0530154
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530155 if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) {
156 String def = PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + EXTEND + SPACE;
157 for (JavaQualifiedTypeInfo info : holder.getExtendsList()) {
158 if (!holder.getExtendedClassStore().get(info)) {
159 def = def + info.getClassInfo() + COMMA + SPACE;
160 } else {
161 def = def + info.getPkgInfo() + PERIOD + info.getClassInfo() + COMMA + SPACE;
162 }
163 }
164
165 def = trimAtLast(def, COMMA);
166
167 return def + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
168 }
169 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530170 }
171
172 /**
173 * Returns builder interface file class definition.
174 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530175 * @param yangName java class name, corresponding to which the builder class
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530176 * is being generated
Bharat saraswal870c56f2016-02-20 21:57:16 +0530177 * @return definition
178 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530179 private static String getBuilderInterfaceDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530180 return INTERFACE + SPACE + yangName + BUILDER + SPACE + OPEN_CURLY_BRACKET + NEW_LINE + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530181 }
182
183 /**
184 * Returns builder file class definition.
185 *
186 * @param yangName file name
187 * @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 saraswal33dfa012016-05-17 19:59:16 +0530201 return PUBLIC + SPACE + FINAL + SPACE + CLASS + SPACE + yangName + IMPL + SPACE + IMPLEMENTS + SPACE
202 + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
203 }
204
205 /**
206 * Returns impl file class definition.
207 *
208 * @param yangName file name
209 * @return definition
210 */
211 private static String getClassDefinition(String yangName) {
212 return PUBLIC + SPACE + CLASS + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530213 }
214
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530215 /**
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530216 * Returns type file class definition.
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530217 *
218 * @param yangName file name
219 * @return definition
220 */
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530221 private static String getTypeClassDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530222 return PUBLIC + SPACE + FINAL + SPACE + CLASS + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530223 }
Gaurav Agrawal56527662016-04-20 15:49:17 +0530224
225 /**
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530226 * Returns RPC file interface definition.
Gaurav Agrawal56527662016-04-20 15:49:17 +0530227 *
228 * @param yangName file name
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530229 * @param curNode current YANG node
Gaurav Agrawal56527662016-04-20 15:49:17 +0530230 * @return definition
231 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530232 private static String getRpcInterfaceDefinition(String yangName, YangNode curNode) {
233 JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode)
234 .getTempJavaCodeFragmentFiles().getServiceTempFiles().getJavaExtendsListHolder();
235 if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) {
236 curNode = curNode.getChild();
237 while (curNode != null) {
238 if (curNode instanceof YangJavaNotification) {
239 return getRpcInterfaceDefinitionWhenItExtends(yangName, holder);
240 }
241 curNode = curNode.getNextSibling();
242 }
243 }
Bharat saraswalc0e04842016-05-12 13:16:57 +0530244 if (yangName.contains(SERVICE)) {
245 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
246 }
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530247 return PUBLIC + SPACE + CLASS + SPACE + yangName + MANAGER + SPACE + IMPLEMENTS + SPACE + yangName
248 + SERVICE + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
249 }
250
251 /* Provides class definition when RPC interface needs to extends any event.*/
252 private static String getRpcInterfaceDefinitionWhenItExtends(String yangName,
253 JavaExtendsListHolder holder) {
254
255 if (yangName.contains(SERVICE)) {
256 String[] strArray = yangName.split(SERVICE);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530257 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + NEW_LINE + EIGHT_SPACE_INDENTATION
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530258 + EXTEND + SPACE + LISTENER_SERVICE + DIAMOND_OPEN_BRACKET + strArray[0] + EVENT_STRING + COMMA
259 + SPACE + strArray[0] + EVENT_LISTENER_STRING + DIAMOND_CLOSE_BRACKET + SPACE
260 + OPEN_CURLY_BRACKET + NEW_LINE;
261 }
Bharat saraswal33dfa012016-05-17 19:59:16 +0530262 return PUBLIC + SPACE + CLASS + SPACE + yangName + MANAGER + NEW_LINE + EIGHT_SPACE_INDENTATION
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530263 + EXTEND + SPACE + LISTENER_REG + DIAMOND_OPEN_BRACKET + yangName + EVENT_STRING + COMMA + SPACE
Bharat saraswal33dfa012016-05-17 19:59:16 +0530264 + yangName + EVENT_LISTENER_STRING + DIAMOND_CLOSE_BRACKET + NEW_LINE
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530265 + EIGHT_SPACE_INDENTATION + IMPLEMENTS + SPACE + yangName + SERVICE + SPACE + OPEN_CURLY_BRACKET
266 + NEW_LINE;
Gaurav Agrawal56527662016-04-20 15:49:17 +0530267 }
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530268
269 /**
270 * Returns event class definition.
271 *
272 * @param javaName file name
273 * @return definition
274 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530275 private static String getEventDefinition(String javaName, String eventName) {
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530276 String classDef = PUBLIC + SPACE + CLASS + SPACE + javaName + SPACE + "extends AbstractEvent<"
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530277 + javaName + ".Type, " + eventName + ">" + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530278
279 return classDef;
280 }
281
282 /**
283 * Returns event listener interface definition.
284 *
285 * @param javaName file name
286 * @return definition
287 */
288 private static String getEventListenerDefinition(String javaName) {
289 String intfDef = PUBLIC + SPACE + INTERFACE + SPACE + javaName + SPACE + "extends EventListener<"
290 + javaName;
291 if (intfDef.length() < 8) {
292 throw new RuntimeException("Event listener interface name is error");
293 }
Bharat saraswalc0e04842016-05-12 13:16:57 +0530294 intfDef = intfDef.substring(0, intfDef.length() - 8);
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530295 intfDef = intfDef + "Event>" + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
296
297 return intfDef;
298 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530299}