blob: dde4b0356ee0ed96a808abdafb4b006c507e88b5 [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;
janani bdd1314f2016-05-19 17:39:50 +053056import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE;
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 saraswal33dfa012016-05-17 19:59:16 +053059import static org.onosproject.yangutils.utils.UtilConstants.SUBJECT;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053060import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.trimAtLast;
Bharat saraswal870c56f2016-02-20 21:57:16 +053061
62/**
Bharat saraswald9822e92016-04-05 15:13:44 +053063 * Represents generator for class definition of generated files.
Bharat saraswal870c56f2016-02-20 21:57:16 +053064 */
65public final class ClassDefinitionGenerator {
66
67 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053068 * Creates an instance of class definition generator.
Bharat saraswal870c56f2016-02-20 21:57:16 +053069 */
70 private ClassDefinitionGenerator() {
71 }
72
73 /**
Vinod Kumar Sc4216002016-03-03 19:55:30 +053074 * Based on the file type and the YANG name of the file, generate the class
75 * / interface definition start.
Bharat saraswal870c56f2016-02-20 21:57:16 +053076 *
77 * @param genFileTypes generated file type
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053078 * @param yangName class name
Bharat saraswal870c56f2016-02-20 21:57:16 +053079 * @return class definition
80 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +053081 public static String generateClassDefinition(int genFileTypes, String yangName) {
Bharat saraswal870c56f2016-02-20 21:57:16 +053082
83 /**
Gaurav Agrawal56527662016-04-20 15:49:17 +053084 * Based on the file type and the YANG name of the file, generate the
Vinod Kumar Sc4216002016-03-03 19:55:30 +053085 * class / interface definition start.
Bharat saraswal870c56f2016-02-20 21:57:16 +053086 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053087 switch (genFileTypes) {
88 case BUILDER_CLASS_MASK:
Bharat saraswalc0e04842016-05-12 13:16:57 +053089 return getBuilderClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053090 case IMPL_CLASS_MASK:
Bharat saraswal870c56f2016-02-20 21:57:16 +053091 return getImplClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053092 case BUILDER_INTERFACE_MASK:
Vinod Kumar Sc4216002016-03-03 19:55:30 +053093 return getBuilderInterfaceDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053094 case GENERATE_TYPEDEF_CLASS:
95 case GENERATE_UNION_CLASS:
Gaurav Agrawal338735b2016-04-18 18:53:11 +053096 return getTypeClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053097 case GENERATE_ENUM_CLASS:
Bharat saraswald72411a2016-04-19 01:00:16 +053098 return getEnumClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053099 default:
100 return null;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530101 }
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530102 }
103
104 /**
105 * Based on the file type and the YANG name of the file, generate the class
106 * / interface definition start.
107 *
108 * @param genFileTypes generated file type
109 * @param yangName class name
110 * @param curNode current YANG node
111 * @return class definition
112 */
113 public static String generateClassDefinition(int genFileTypes, String yangName, YangNode curNode) {
114
115 /**
116 * Based on the file type and the YANG name of the file, generate the
117 * class / interface definition start.
118 */
119 switch (genFileTypes) {
120 case INTERFACE_MASK:
121 return getInterfaceDefinition(yangName, curNode);
122 case GENERATE_SERVICE_AND_MANAGER:
123 return getRpcInterfaceDefinition(yangName, curNode);
124 case GENERATE_EVENT_CLASS:
Bharat saraswal33dfa012016-05-17 19:59:16 +0530125 String eventName = yangName + SUBJECT;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530126 return getEventDefinition(yangName, eventName);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530127 case GENERATE_EVENT_LISTENER_INTERFACE:
128 return getEventListenerDefinition(yangName);
129 case GENERATE_EVENT_SUBJECT_CLASS:
130 return getClassDefinition(yangName);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530131 default:
132 return null;
133 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530134 }
135
136 /**
Bharat saraswald72411a2016-04-19 01:00:16 +0530137 * Returns enum file class definition.
138 *
139 * @param yangName class name
Gaurav Agrawal56527662016-04-20 15:49:17 +0530140 * @return enum file class definition
Bharat saraswald72411a2016-04-19 01:00:16 +0530141 */
142 private static String getEnumClassDefinition(String yangName) {
143 return PUBLIC + SPACE + ENUM + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
144 }
145
146 /**
Bharat saraswal870c56f2016-02-20 21:57:16 +0530147 * Returns interface file class definition.
148 *
149 * @param yangName file name
150 * @return definition
151 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530152 private static String getInterfaceDefinition(String yangName, YangNode curNode) {
153 JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode)
154 .getTempJavaCodeFragmentFiles().getBeanTempFiles().getJavaExtendsListHolder();
Bharat saraswal870c56f2016-02-20 21:57:16 +0530155
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530156 if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) {
157 String def = PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + EXTEND + SPACE;
158 for (JavaQualifiedTypeInfo info : holder.getExtendsList()) {
159 if (!holder.getExtendedClassStore().get(info)) {
160 def = def + info.getClassInfo() + COMMA + SPACE;
161 } else {
162 def = def + info.getPkgInfo() + PERIOD + info.getClassInfo() + COMMA + SPACE;
163 }
164 }
165
166 def = trimAtLast(def, COMMA);
167
168 return def + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
169 }
170 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530171 }
172
173 /**
174 * Returns builder interface file class definition.
175 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530176 * @param yangName java class name, corresponding to which the builder class
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530177 * is being generated
Bharat saraswal870c56f2016-02-20 21:57:16 +0530178 * @return definition
179 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530180 private static String getBuilderInterfaceDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530181 return INTERFACE + SPACE + yangName + BUILDER + SPACE + OPEN_CURLY_BRACKET + NEW_LINE + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530182 }
183
184 /**
185 * Returns builder file class definition.
186 *
187 * @param yangName file name
188 * @return definition
189 */
Bharat saraswalc0e04842016-05-12 13:16:57 +0530190 private static String getBuilderClassDefinition(String yangName) {
191 return PUBLIC + SPACE + CLASS + SPACE + yangName + BUILDER + SPACE + IMPLEMENTS + SPACE + yangName + PERIOD
192 + yangName + BUILDER + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530193 }
194
195 /**
196 * Returns impl file class definition.
197 *
198 * @param yangName file name
199 * @return definition
200 */
201 private static String getImplClassDefinition(String yangName) {
Bharat saraswal33dfa012016-05-17 19:59:16 +0530202 return PUBLIC + SPACE + FINAL + SPACE + CLASS + SPACE + yangName + IMPL + SPACE + IMPLEMENTS + SPACE
203 + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
204 }
205
206 /**
207 * Returns impl file class definition.
208 *
209 * @param yangName file name
210 * @return definition
211 */
212 private static String getClassDefinition(String yangName) {
213 return PUBLIC + SPACE + CLASS + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530214 }
215
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530216 /**
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530217 * Returns type file class definition.
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530218 *
219 * @param yangName file name
220 * @return definition
221 */
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530222 private static String getTypeClassDefinition(String yangName) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530223 return PUBLIC + SPACE + FINAL + SPACE + CLASS + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530224 }
Gaurav Agrawal56527662016-04-20 15:49:17 +0530225
226 /**
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530227 * Returns RPC file interface definition.
Gaurav Agrawal56527662016-04-20 15:49:17 +0530228 *
229 * @param yangName file name
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530230 * @param curNode current YANG node
Gaurav Agrawal56527662016-04-20 15:49:17 +0530231 * @return definition
232 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530233 private static String getRpcInterfaceDefinition(String yangName, YangNode curNode) {
234 JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode)
235 .getTempJavaCodeFragmentFiles().getServiceTempFiles().getJavaExtendsListHolder();
236 if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) {
237 curNode = curNode.getChild();
238 while (curNode != null) {
239 if (curNode instanceof YangJavaNotification) {
240 return getRpcInterfaceDefinitionWhenItExtends(yangName, holder);
241 }
242 curNode = curNode.getNextSibling();
243 }
244 }
janani bdd1314f2016-05-19 17:39:50 +0530245 if (yangName.matches(REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE)) {
Bharat saraswalc0e04842016-05-12 13:16:57 +0530246 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
247 }
janani bdd1314f2016-05-19 17:39:50 +0530248 return PUBLIC + SPACE + CLASS + SPACE + yangName + SPACE + IMPLEMENTS + SPACE
249 + yangName.substring(0, yangName.length() - 7) + SERVICE + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530250 }
251
252 /* Provides class definition when RPC interface needs to extends any event.*/
253 private static String getRpcInterfaceDefinitionWhenItExtends(String yangName,
254 JavaExtendsListHolder holder) {
255
janani bdd1314f2016-05-19 17:39:50 +0530256 if (yangName.matches(REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE)) {
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530257 String[] strArray = yangName.split(SERVICE);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530258 return PUBLIC + SPACE + INTERFACE + SPACE + yangName + NEW_LINE + EIGHT_SPACE_INDENTATION
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530259 + EXTEND + SPACE + LISTENER_SERVICE + DIAMOND_OPEN_BRACKET + strArray[0] + EVENT_STRING + COMMA
260 + SPACE + strArray[0] + EVENT_LISTENER_STRING + DIAMOND_CLOSE_BRACKET + SPACE
261 + OPEN_CURLY_BRACKET + NEW_LINE;
262 }
janani bdd1314f2016-05-19 17:39:50 +0530263 yangName = yangName.substring(0, yangName.length() - 7);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530264 return PUBLIC + SPACE + CLASS + SPACE + yangName + MANAGER + NEW_LINE + EIGHT_SPACE_INDENTATION
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530265 + EXTEND + SPACE + LISTENER_REG + DIAMOND_OPEN_BRACKET + yangName + EVENT_STRING + COMMA + SPACE
Bharat saraswal33dfa012016-05-17 19:59:16 +0530266 + yangName + EVENT_LISTENER_STRING + DIAMOND_CLOSE_BRACKET + NEW_LINE
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530267 + EIGHT_SPACE_INDENTATION + IMPLEMENTS + SPACE + yangName + SERVICE + SPACE + OPEN_CURLY_BRACKET
268 + NEW_LINE;
Gaurav Agrawal56527662016-04-20 15:49:17 +0530269 }
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530270
271 /**
272 * Returns event class definition.
273 *
274 * @param javaName file name
275 * @return definition
276 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530277 private static String getEventDefinition(String javaName, String eventName) {
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530278 String classDef = PUBLIC + SPACE + CLASS + SPACE + javaName + SPACE + "extends AbstractEvent<"
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530279 + javaName + ".Type, " + eventName + ">" + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530280
281 return classDef;
282 }
283
284 /**
285 * Returns event listener interface definition.
286 *
287 * @param javaName file name
288 * @return definition
289 */
290 private static String getEventListenerDefinition(String javaName) {
291 String intfDef = PUBLIC + SPACE + INTERFACE + SPACE + javaName + SPACE + "extends EventListener<"
292 + javaName;
293 if (intfDef.length() < 8) {
294 throw new RuntimeException("Event listener interface name is error");
295 }
Bharat saraswalc0e04842016-05-12 13:16:57 +0530296 intfDef = intfDef.substring(0, intfDef.length() - 8);
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530297 intfDef = intfDef + "Event>" + SPACE + OPEN_CURLY_BRACKET + NEW_LINE;
298
299 return intfDef;
300 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530301}