blob: 1057bded3e1f66499e4fcb57c9f5cca46ff7f6b9 [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 saraswalb1170bd2016-07-14 13:26:18 +053019import java.util.List;
20
21import org.onosproject.yangutils.datamodel.YangNode;
Bharat saraswalb551aae2016-07-14 15:18:20 +053022import org.onosproject.yangutils.translator.tojava.JavaCodeGeneratorInfo;
Vinod Kumar S38046502016-03-23 15:30:27 +053023import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
Bharat saraswalb551aae2016-07-14 15:18:20 +053024import org.onosproject.yangutils.translator.tojava.TempJavaServiceFragmentFiles;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053025import org.onosproject.yangutils.utils.io.impl.YangPluginConfig;
Bharat saraswale2d51d62016-03-23 19:40:35 +053026
Bharat saraswald72411a2016-04-19 01:00:16 +053027import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getEnumJavaAttribute;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053028import static org.onosproject.yangutils.utils.UtilConstants.ACTIVATE_ANNOTATION_IMPORT;
Bharat saraswalb551aae2016-07-14 15:18:20 +053029import static org.onosproject.yangutils.utils.UtilConstants.CLASS_STRING;
Bharat saraswale2d51d62016-03-23 19:40:35 +053030import static org.onosproject.yangutils.utils.UtilConstants.CLOSE_CURLY_BRACKET;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053031import static org.onosproject.yangutils.utils.UtilConstants.CLOSE_PARENTHESIS;
Bharat saraswald72411a2016-04-19 01:00:16 +053032import static org.onosproject.yangutils.utils.UtilConstants.COMMA;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053033import static org.onosproject.yangutils.utils.UtilConstants.COMPONENT_ANNOTATION;
34import static org.onosproject.yangutils.utils.UtilConstants.COMPONENT_ANNOTATION_IMPORT;
35import static org.onosproject.yangutils.utils.UtilConstants.DEACTIVATE_ANNOTATION_IMPORT;
Bharat saraswale2d51d62016-03-23 19:40:35 +053036import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_CLOSE_BRACKET;
37import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_OPEN_BRACKET;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053038import static org.onosproject.yangutils.utils.UtilConstants.ENUM;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053039import static org.onosproject.yangutils.utils.UtilConstants.EQUAL;
40import static org.onosproject.yangutils.utils.UtilConstants.FOUR_SPACE_INDENTATION;
Bharat saraswalb551aae2016-07-14 15:18:20 +053041import static org.onosproject.yangutils.utils.UtilConstants.HASH_MAP;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053042import static org.onosproject.yangutils.utils.UtilConstants.IMMEDIATE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053043import static org.onosproject.yangutils.utils.UtilConstants.IMPORT;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053044import static org.onosproject.yangutils.utils.UtilConstants.INT;
Bharat saraswale707f032016-07-14 23:33:55 +053045import static org.onosproject.yangutils.utils.UtilConstants.INT_MAX_RANGE_ATTR;
46import static org.onosproject.yangutils.utils.UtilConstants.INT_MIN_RANGE_ATTR;
Bharat saraswale2d51d62016-03-23 19:40:35 +053047import static org.onosproject.yangutils.utils.UtilConstants.LIST;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053048import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_SERVICE;
49import static org.onosproject.yangutils.utils.UtilConstants.LOGGER_FACTORY_IMPORT;
50import static org.onosproject.yangutils.utils.UtilConstants.LOGGER_IMPORT;
Bharat saraswale707f032016-07-14 23:33:55 +053051import static org.onosproject.yangutils.utils.UtilConstants.LONG_MAX_RANGE_ATTR;
52import static org.onosproject.yangutils.utils.UtilConstants.LONG_MIN_RANGE_ATTR;
Bharat saraswalb551aae2016-07-14 15:18:20 +053053import static org.onosproject.yangutils.utils.UtilConstants.MAP;
54import static org.onosproject.yangutils.utils.UtilConstants.NEW;
Bharat saraswale2d51d62016-03-23 19:40:35 +053055import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053056import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053057import static org.onosproject.yangutils.utils.UtilConstants.OPEN_PARENTHESIS;
Bharat saraswale2d51d62016-03-23 19:40:35 +053058import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
59import static org.onosproject.yangutils.utils.UtilConstants.PRIVATE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053060import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC;
Bharat saraswalb551aae2016-07-14 15:18:20 +053061import static org.onosproject.yangutils.utils.UtilConstants.QUESTION_MARK;
Bharat saraswale2d51d62016-03-23 19:40:35 +053062import static org.onosproject.yangutils.utils.UtilConstants.SEMI_COLAN;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053063import static org.onosproject.yangutils.utils.UtilConstants.SERVICE_ANNOTATION;
64import static org.onosproject.yangutils.utils.UtilConstants.SERVICE_ANNOTATION_IMPORT;
Bharat saraswale2d51d62016-03-23 19:40:35 +053065import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053066import static org.onosproject.yangutils.utils.UtilConstants.TRUE;
67import static org.onosproject.yangutils.utils.UtilConstants.TYPE;
Bharat saraswale707f032016-07-14 23:33:55 +053068import static org.onosproject.yangutils.utils.UtilConstants.UINT_MAX_RANGE_ATTR;
69import static org.onosproject.yangutils.utils.UtilConstants.UINT_MIN_RANGE_ATTR;
70import static org.onosproject.yangutils.utils.UtilConstants.ULONG_MAX_RANGE_ATTR;
71import static org.onosproject.yangutils.utils.UtilConstants.ULONG_MIN_RANGE_ATTR;
Bharat saraswalb551aae2016-07-14 15:18:20 +053072import static org.onosproject.yangutils.utils.UtilConstants.YANG_AUGMENTED_INFO;
Bharat saraswald72411a2016-04-19 01:00:16 +053073import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.ENUM_ATTRIBUTE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053074import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.getJavaDoc;
75import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getSmallCase;
76import static java.util.Collections.sort;
Bharat saraswal870c56f2016-02-20 21:57:16 +053077
78/**
Bharat saraswald9822e92016-04-05 15:13:44 +053079 * Represents utility class to generate the java snippet.
Bharat saraswal870c56f2016-02-20 21:57:16 +053080 */
81public final class JavaCodeSnippetGen {
82
83 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053084 * Creates an instance of java code snippet gen.
Bharat saraswal870c56f2016-02-20 21:57:16 +053085 */
86 private JavaCodeSnippetGen() {
87 }
88
89 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053090 * Returns the java file header comment.
Bharat saraswal870c56f2016-02-20 21:57:16 +053091 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +053092 * @return the java file header comment
Bharat saraswal870c56f2016-02-20 21:57:16 +053093 */
94 public static String getFileHeaderComment() {
95
96 /**
97 * TODO return the file header.
98 */
99 return null;
100 }
101
102 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530103 * Returns the textual java code information corresponding to the import list.
Bharat saraswal870c56f2016-02-20 21:57:16 +0530104 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530105 * @param importInfo import info
Bharat saraswald50c6382016-07-14 21:57:13 +0530106 * @return the textual java code information corresponding to the import list
Bharat saraswal870c56f2016-02-20 21:57:16 +0530107 */
Bharat saraswale707f032016-07-14 23:33:55 +0530108 static String getImportText(JavaQualifiedTypeInfo importInfo) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530109 return IMPORT + importInfo.getPkgInfo() + PERIOD + importInfo.getClassInfo() + SEMI_COLAN + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530110 }
111
112 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530113 * Returns the textual java code for attribute definition in class.
Bharat saraswal870c56f2016-02-20 21:57:16 +0530114 *
Bharat saraswale707f032016-07-14 23:33:55 +0530115 * @param javaAttributeTypePkg Package of the attribute type
116 * @param javaAttributeType java attribute type
117 * @param javaAttributeName name of the attribute
118 * @param isList is list attribute
119 * @param attributeAccessType attribute access type
120 * @return the textual java code for attribute definition in class
Bharat saraswal870c56f2016-02-20 21:57:16 +0530121 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530122 public static String getJavaAttributeDefination(String javaAttributeTypePkg, String javaAttributeType,
Bharat saraswale707f032016-07-14 23:33:55 +0530123 String javaAttributeName, boolean isList,
124 String attributeAccessType) {
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530125
Shankara-Huaweib9999eb2016-07-14 16:53:09 +0530126 String attributeDefination = attributeAccessType + SPACE;
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530127
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530128 if (!isList) {
129 if (javaAttributeTypePkg != null) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530130 attributeDefination = attributeDefination + javaAttributeTypePkg + PERIOD;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530131 }
132
Bharat saraswale2d51d62016-03-23 19:40:35 +0530133 attributeDefination = attributeDefination + javaAttributeType + SPACE + javaAttributeName + SEMI_COLAN
134 + NEW_LINE;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530135 } else {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530136 attributeDefination = attributeDefination + LIST + DIAMOND_OPEN_BRACKET;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530137 if (javaAttributeTypePkg != null) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530138 attributeDefination = attributeDefination + javaAttributeTypePkg + PERIOD;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530139 }
140
Bharat saraswale2d51d62016-03-23 19:40:35 +0530141 attributeDefination = attributeDefination + javaAttributeType + DIAMOND_CLOSE_BRACKET + SPACE
142 + javaAttributeName + SEMI_COLAN + NEW_LINE;
Bharat saraswal594bc6d2016-02-22 22:15:21 +0530143 }
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530144 return attributeDefination;
Bharat saraswal594bc6d2016-02-22 22:15:21 +0530145 }
146
147 /**
148 * Returns list attribute string.
149 *
150 * @param type attribute type
151 * @return list attribute string
152 */
Bharat saraswalcad0e652016-05-26 23:48:38 +0530153 public static String getListAttribute(String type) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530154 return LIST + DIAMOND_OPEN_BRACKET + type + DIAMOND_CLOSE_BRACKET;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530155 }
156
157 /**
Bharat saraswald50c6382016-07-14 21:57:13 +0530158 * Returns based on the file type and the YANG name of the file, generate the class / interface definition close.
Bharat saraswal870c56f2016-02-20 21:57:16 +0530159 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530160 * @return corresponding textual java code information
Bharat saraswal870c56f2016-02-20 21:57:16 +0530161 */
Vinod Kumar S38046502016-03-23 15:30:27 +0530162 public static String getJavaClassDefClose() {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530163 return CLOSE_CURLY_BRACKET;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530164 }
Bharat saraswald72411a2016-04-19 01:00:16 +0530165
166 /**
167 * Returns string for enum's attribute.
168 *
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530169 * @param name name of attribute
170 * @param value value of the enum
Bharat saraswal33dfa012016-05-17 19:59:16 +0530171 * @param pluginConfig plugin configurations
Bharat saraswald72411a2016-04-19 01:00:16 +0530172 * @return string for enum's attribute
173 */
Bharat saraswal33dfa012016-05-17 19:59:16 +0530174 public static String generateEnumAttributeString(String name, int value, YangPluginConfig pluginConfig) {
175 return getJavaDoc(ENUM_ATTRIBUTE, name, false, pluginConfig) + FOUR_SPACE_INDENTATION
Bharat saraswalc0e04842016-05-12 13:16:57 +0530176 + getEnumJavaAttribute(name).toUpperCase() + OPEN_PARENTHESIS
177 + value + CLOSE_PARENTHESIS + COMMA + NEW_LINE;
Bharat saraswald72411a2016-04-19 01:00:16 +0530178 }
179
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530180 /**
181 * Adds annotations imports.
182 *
183 * @param imports list if imports
184 * @param operation to add or to delete
185 */
186 public static void addAnnotationsImports(List<String> imports, boolean operation) {
187 if (operation) {
188 imports.add(ACTIVATE_ANNOTATION_IMPORT);
189 imports.add(DEACTIVATE_ANNOTATION_IMPORT);
190 imports.add(COMPONENT_ANNOTATION_IMPORT);
191 imports.add(SERVICE_ANNOTATION_IMPORT);
192 imports.add(LOGGER_FACTORY_IMPORT);
193 imports.add(LOGGER_IMPORT);
194 } else {
195 imports.remove(ACTIVATE_ANNOTATION_IMPORT);
196 imports.remove(DEACTIVATE_ANNOTATION_IMPORT);
197 imports.remove(COMPONENT_ANNOTATION_IMPORT);
198 imports.remove(SERVICE_ANNOTATION_IMPORT);
199 imports.remove(LOGGER_FACTORY_IMPORT);
200 imports.remove(LOGGER_IMPORT);
201 }
202 sortImports(imports);
203 }
204
205 /**
206 * Returns sorted import list.
207 *
208 * @param imports import list
209 * @return sorted import list
210 */
211 public static List<String> sortImports(List<String> imports) {
212 sort(imports);
213 return imports;
214 }
215
216 /**
217 * Returns event enum start.
218 *
219 * @return event enum start
220 */
Bharat saraswale707f032016-07-14 23:33:55 +0530221 static String getEventEnumTypeStart() {
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530222 return FOUR_SPACE_INDENTATION + PUBLIC + SPACE + ENUM + SPACE + TYPE + SPACE + OPEN_CURLY_BRACKET
223 + NEW_LINE;
224 }
225
226 /**
227 * Adds listener's imports.
228 *
229 * @param curNode currentYangNode.
230 * @param imports import list
231 * @param operation add or remove
232 * @param classInfo class info to be added to import list
233 */
234 public static void addListenersImport(YangNode curNode, List<String> imports, boolean operation,
235 String classInfo) {
236 String thisImport = "";
Bharat saraswalb551aae2016-07-14 15:18:20 +0530237 TempJavaServiceFragmentFiles tempJavaServiceFragmentFiles = ((JavaCodeGeneratorInfo) curNode)
238 .getTempJavaCodeFragmentFiles().getServiceTempFiles();
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530239 if (classInfo.equals(LISTENER_SERVICE)) {
Bharat saraswalb551aae2016-07-14 15:18:20 +0530240 thisImport = tempJavaServiceFragmentFiles.getJavaImportData().getListenerServiceImport();
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530241 performOperationOnImports(imports, thisImport, operation);
242 } else {
Bharat saraswalb551aae2016-07-14 15:18:20 +0530243 thisImport = tempJavaServiceFragmentFiles.getJavaImportData().getListenerRegistryImport();
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530244 performOperationOnImports(imports, thisImport, operation);
245 }
246 }
247
248 /**
249 * Performs given operations on import list.
250 *
251 * @param imports list of imports
252 * @param curImport current import
253 * @param operation add or remove
254 * @return import list
255 */
256 private static List<String> performOperationOnImports(List<String> imports, String curImport,
257 boolean operation) {
258 if (operation) {
259 imports.add(curImport);
260 } else {
261 imports.remove(curImport);
262 }
263 sortImports(imports);
264 return imports;
265 }
266
267 /**
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530268 * Returns integer attribute for enum's class to get the values.
269 *
270 * @param className enum's class name
271 * @return enum's attribute
272 */
Bharat saraswale707f032016-07-14 23:33:55 +0530273 static String getEnumsValueAttribute(String className) {
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530274 return NEW_LINE + FOUR_SPACE_INDENTATION + PRIVATE + SPACE + INT + SPACE + getSmallCase(className)
275 + SEMI_COLAN + NEW_LINE;
276 }
277
278 /**
279 * Returns component string.
280 *
281 * @return component string
282 */
Bharat saraswale707f032016-07-14 23:33:55 +0530283 static String addComponentString() {
Bharat saraswalb551aae2016-07-14 15:18:20 +0530284 return NEW_LINE + COMPONENT_ANNOTATION + OPEN_PARENTHESIS + IMMEDIATE + SPACE
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530285 + EQUAL + SPACE + TRUE + CLOSE_PARENTHESIS + NEW_LINE + SERVICE_ANNOTATION;
286 }
Bharat saraswalb551aae2016-07-14 15:18:20 +0530287
288 /**
289 * Returns attribute for augmentation.
290 *
291 * @return attribute for augmentation
292 */
Bharat saraswale707f032016-07-14 23:33:55 +0530293 static String addAugmentationAttribute() {
Bharat saraswalb551aae2016-07-14 15:18:20 +0530294 return NEW_LINE + FOUR_SPACE_INDENTATION + PRIVATE + SPACE + MAP + DIAMOND_OPEN_BRACKET + CLASS_STRING
295 + DIAMOND_OPEN_BRACKET + QUESTION_MARK + DIAMOND_CLOSE_BRACKET + COMMA + SPACE + YANG_AUGMENTED_INFO
296 + DIAMOND_CLOSE_BRACKET + SPACE + getSmallCase(YANG_AUGMENTED_INFO) + MAP + SPACE + EQUAL + SPACE +
297 NEW + SPACE + HASH_MAP + DIAMOND_OPEN_BRACKET + DIAMOND_CLOSE_BRACKET + OPEN_PARENTHESIS
298 + CLOSE_PARENTHESIS + SEMI_COLAN;
299 }
Bharat saraswale707f032016-07-14 23:33:55 +0530300
301 /**
302 * Adds attribute for int ranges.
303 *
304 * @param modifier modifier for attribute
305 * @param addFirst true if int need to be added fist.
306 * @return attribute for int ranges
307 */
308 static String addStaticAttributeIntRange(String modifier, boolean addFirst) {
309 if (addFirst) {
310 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + INT_MIN_RANGE_ATTR + FOUR_SPACE_INDENTATION +
311 modifier +
312 SPACE + INT_MAX_RANGE_ATTR;
313 } else {
314 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + UINT_MIN_RANGE_ATTR + FOUR_SPACE_INDENTATION +
315 modifier + SPACE + UINT_MAX_RANGE_ATTR;
316 }
317 }
318
319 /**
320 * Adds attribute for long ranges.
321 *
322 * @param modifier modifier for attribute
323 * @param addFirst if need to be added first
324 * @return attribute for long ranges
325 */
326 static String addStaticAttributeLongRange(String modifier, boolean addFirst) {
327 if (addFirst) {
328 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + LONG_MIN_RANGE_ATTR + FOUR_SPACE_INDENTATION +
329 modifier + SPACE + LONG_MAX_RANGE_ATTR;
330 } else {
331 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + ULONG_MIN_RANGE_ATTR +
332 FOUR_SPACE_INDENTATION + modifier + SPACE + ULONG_MAX_RANGE_ATTR;
333 }
334 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530335}