blob: 01fb650ef0ffc52253cf34f1bd2467ea4a60aac9 [file] [log] [blame]
Bharat saraswal97459962016-02-20 21:57:16 +05301/*
Brian O'Connor0f7908b2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Bharat saraswal97459962016-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 saraswald14cbe82016-07-14 13:26:18 +053019import java.util.List;
20
21import org.onosproject.yangutils.datamodel.YangNode;
Bharat saraswal8beac342016-08-04 02:00:03 +053022import org.onosproject.yangutils.datamodel.javadatamodel.YangPluginConfig;
Bharat saraswalaf413b82016-07-14 15:18:20 +053023import org.onosproject.yangutils.translator.tojava.JavaCodeGeneratorInfo;
Shankara-Huaweib7564772016-08-02 18:13:13 +053024import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfoTranslator;
Bharat saraswalaf413b82016-07-14 15:18:20 +053025import org.onosproject.yangutils.translator.tojava.TempJavaServiceFragmentFiles;
Bharat saraswal84366c52016-03-23 19:40:35 +053026
Bharat saraswal68fa0d12016-04-19 01:00:16 +053027import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getEnumJavaAttribute;
Bharat saraswal8beac342016-08-04 02:00:03 +053028import static org.onosproject.yangutils.utils.UtilConstants.ARRAY_LIST;
Bharat saraswalaf413b82016-07-14 15:18:20 +053029import static org.onosproject.yangutils.utils.UtilConstants.CLASS_STRING;
Bharat saraswal84366c52016-03-23 19:40:35 +053030import static org.onosproject.yangutils.utils.UtilConstants.CLOSE_CURLY_BRACKET;
Bharat saraswale2bc60d2016-04-16 02:28:25 +053031import static org.onosproject.yangutils.utils.UtilConstants.CLOSE_PARENTHESIS;
Bharat saraswal68fa0d12016-04-19 01:00:16 +053032import static org.onosproject.yangutils.utils.UtilConstants.COMMA;
Bharat saraswal84366c52016-03-23 19:40:35 +053033import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_CLOSE_BRACKET;
34import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_OPEN_BRACKET;
Bharat saraswal8beac342016-08-04 02:00:03 +053035import static org.onosproject.yangutils.utils.UtilConstants.EIGHT_SPACE_INDENTATION;
Bharat saraswald14cbe82016-07-14 13:26:18 +053036import static org.onosproject.yangutils.utils.UtilConstants.ENUM;
Bharat saraswale2bc60d2016-04-16 02:28:25 +053037import static org.onosproject.yangutils.utils.UtilConstants.EQUAL;
38import static org.onosproject.yangutils.utils.UtilConstants.FOUR_SPACE_INDENTATION;
Bharat saraswalaf413b82016-07-14 15:18:20 +053039import static org.onosproject.yangutils.utils.UtilConstants.HASH_MAP;
Bharat saraswal84366c52016-03-23 19:40:35 +053040import static org.onosproject.yangutils.utils.UtilConstants.IMPORT;
Bharat saraswald14cbe82016-07-14 13:26:18 +053041import static org.onosproject.yangutils.utils.UtilConstants.INT;
Bharat saraswal64e7e232016-07-14 23:33:55 +053042import static org.onosproject.yangutils.utils.UtilConstants.INT_MAX_RANGE_ATTR;
43import static org.onosproject.yangutils.utils.UtilConstants.INT_MIN_RANGE_ATTR;
Bharat saraswal84366c52016-03-23 19:40:35 +053044import static org.onosproject.yangutils.utils.UtilConstants.LIST;
Bharat saraswald14cbe82016-07-14 13:26:18 +053045import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_SERVICE;
Bharat saraswal64e7e232016-07-14 23:33:55 +053046import static org.onosproject.yangutils.utils.UtilConstants.LONG_MAX_RANGE_ATTR;
47import static org.onosproject.yangutils.utils.UtilConstants.LONG_MIN_RANGE_ATTR;
Bharat saraswalaf413b82016-07-14 15:18:20 +053048import static org.onosproject.yangutils.utils.UtilConstants.MAP;
49import static org.onosproject.yangutils.utils.UtilConstants.NEW;
Bharat saraswal84366c52016-03-23 19:40:35 +053050import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
Bharat saraswal8beac342016-08-04 02:00:03 +053051import static org.onosproject.yangutils.utils.UtilConstants.OBJECT_STRING;
Bharat saraswald14cbe82016-07-14 13:26:18 +053052import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET;
Bharat saraswale2bc60d2016-04-16 02:28:25 +053053import static org.onosproject.yangutils.utils.UtilConstants.OPEN_PARENTHESIS;
Bharat saraswal84366c52016-03-23 19:40:35 +053054import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
55import static org.onosproject.yangutils.utils.UtilConstants.PRIVATE;
Bharat saraswald14cbe82016-07-14 13:26:18 +053056import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC;
Bharat saraswalaf413b82016-07-14 15:18:20 +053057import static org.onosproject.yangutils.utils.UtilConstants.QUESTION_MARK;
Bharat saraswal84366c52016-03-23 19:40:35 +053058import static org.onosproject.yangutils.utils.UtilConstants.SEMI_COLAN;
59import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswald14cbe82016-07-14 13:26:18 +053060import static org.onosproject.yangutils.utils.UtilConstants.TYPE;
Bharat saraswal64e7e232016-07-14 23:33:55 +053061import static org.onosproject.yangutils.utils.UtilConstants.UINT_MAX_RANGE_ATTR;
62import static org.onosproject.yangutils.utils.UtilConstants.UINT_MIN_RANGE_ATTR;
63import static org.onosproject.yangutils.utils.UtilConstants.ULONG_MAX_RANGE_ATTR;
64import static org.onosproject.yangutils.utils.UtilConstants.ULONG_MIN_RANGE_ATTR;
Bharat saraswalaf413b82016-07-14 15:18:20 +053065import static org.onosproject.yangutils.utils.UtilConstants.YANG_AUGMENTED_INFO;
Bharat saraswal68fa0d12016-04-19 01:00:16 +053066import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.ENUM_ATTRIBUTE;
Bharat saraswald14cbe82016-07-14 13:26:18 +053067import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.getJavaDoc;
68import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getSmallCase;
69import static java.util.Collections.sort;
Bharat saraswal97459962016-02-20 21:57:16 +053070
71/**
Bharat saraswal63f26fb2016-04-05 15:13:44 +053072 * Represents utility class to generate the java snippet.
Bharat saraswal97459962016-02-20 21:57:16 +053073 */
74public final class JavaCodeSnippetGen {
75
76 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +053077 * Creates an instance of java code snippet gen.
Bharat saraswal97459962016-02-20 21:57:16 +053078 */
79 private JavaCodeSnippetGen() {
80 }
81
82 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +053083 * Returns the java file header comment.
Bharat saraswal97459962016-02-20 21:57:16 +053084 *
Vinod Kumar S08710982016-03-03 19:55:30 +053085 * @return the java file header comment
Bharat saraswal97459962016-02-20 21:57:16 +053086 */
87 public static String getFileHeaderComment() {
88
Bharat saraswal8beac342016-08-04 02:00:03 +053089 /*
Bharat saraswal97459962016-02-20 21:57:16 +053090 * TODO return the file header.
91 */
92 return null;
93 }
94
95 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +053096 * Returns the textual java code information corresponding to the import list.
Bharat saraswal97459962016-02-20 21:57:16 +053097 *
Vinod Kumar S08710982016-03-03 19:55:30 +053098 * @param importInfo import info
Bharat saraswal039f59c2016-07-14 21:57:13 +053099 * @return the textual java code information corresponding to the import list
Bharat saraswal97459962016-02-20 21:57:16 +0530100 */
Shankara-Huaweib7564772016-08-02 18:13:13 +0530101 static String getImportText(JavaQualifiedTypeInfoTranslator importInfo) {
Bharat saraswal84366c52016-03-23 19:40:35 +0530102 return IMPORT + importInfo.getPkgInfo() + PERIOD + importInfo.getClassInfo() + SEMI_COLAN + NEW_LINE;
Bharat saraswal97459962016-02-20 21:57:16 +0530103 }
104
105 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +0530106 * Returns the textual java code for attribute definition in class.
Bharat saraswal97459962016-02-20 21:57:16 +0530107 *
Bharat saraswal64e7e232016-07-14 23:33:55 +0530108 * @param javaAttributeTypePkg Package of the attribute type
109 * @param javaAttributeType java attribute type
110 * @param javaAttributeName name of the attribute
111 * @param isList is list attribute
112 * @param attributeAccessType attribute access type
113 * @return the textual java code for attribute definition in class
Bharat saraswal97459962016-02-20 21:57:16 +0530114 */
Bharat saraswal8beac342016-08-04 02:00:03 +0530115 public static String getJavaAttributeDefinition(String javaAttributeTypePkg, String javaAttributeType,
Bharat saraswal64e7e232016-07-14 23:33:55 +0530116 String javaAttributeName, boolean isList,
117 String attributeAccessType) {
Vinod Kumar S08710982016-03-03 19:55:30 +0530118
Bharat saraswal8beac342016-08-04 02:00:03 +0530119 String attributeDefinition = attributeAccessType + SPACE;
Vinod Kumar S08710982016-03-03 19:55:30 +0530120
Bharat saraswal022dae92016-03-04 20:08:09 +0530121 if (!isList) {
122 if (javaAttributeTypePkg != null) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530123 attributeDefinition = attributeDefinition + javaAttributeTypePkg + PERIOD;
Bharat saraswal022dae92016-03-04 20:08:09 +0530124 }
125
Bharat saraswal8beac342016-08-04 02:00:03 +0530126 attributeDefinition = attributeDefinition + javaAttributeType + SPACE + javaAttributeName + SEMI_COLAN
Bharat saraswal84366c52016-03-23 19:40:35 +0530127 + NEW_LINE;
Bharat saraswal022dae92016-03-04 20:08:09 +0530128 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530129 attributeDefinition = attributeDefinition + LIST + DIAMOND_OPEN_BRACKET;
Bharat saraswal022dae92016-03-04 20:08:09 +0530130 if (javaAttributeTypePkg != null) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530131 attributeDefinition = attributeDefinition + javaAttributeTypePkg + PERIOD;
Bharat saraswal022dae92016-03-04 20:08:09 +0530132 }
133
Bharat saraswal8beac342016-08-04 02:00:03 +0530134 attributeDefinition = attributeDefinition + javaAttributeType + DIAMOND_CLOSE_BRACKET + SPACE
135 + javaAttributeName + SPACE + EQUAL + SPACE + NEW + SPACE + ARRAY_LIST + SEMI_COLAN + NEW_LINE;
Bharat saraswal5e3c45c2016-02-22 22:15:21 +0530136 }
Bharat saraswal8beac342016-08-04 02:00:03 +0530137 return attributeDefinition;
Bharat saraswal97459962016-02-20 21:57:16 +0530138 }
139
140 /**
Bharat saraswal039f59c2016-07-14 21:57:13 +0530141 * Returns based on the file type and the YANG name of the file, generate the class / interface definition close.
Bharat saraswal97459962016-02-20 21:57:16 +0530142 *
Vinod Kumar S08710982016-03-03 19:55:30 +0530143 * @return corresponding textual java code information
Bharat saraswal97459962016-02-20 21:57:16 +0530144 */
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530145 public static String getJavaClassDefClose() {
Bharat saraswal84366c52016-03-23 19:40:35 +0530146 return CLOSE_CURLY_BRACKET;
Bharat saraswal97459962016-02-20 21:57:16 +0530147 }
Bharat saraswal68fa0d12016-04-19 01:00:16 +0530148
149 /**
150 * Returns string for enum's attribute.
151 *
Bharat saraswald14cbe82016-07-14 13:26:18 +0530152 * @param name name of attribute
153 * @param value value of the enum
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530154 * @param pluginConfig plugin configurations
Bharat saraswal68fa0d12016-04-19 01:00:16 +0530155 * @return string for enum's attribute
156 */
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530157 public static String generateEnumAttributeString(String name, int value, YangPluginConfig pluginConfig) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530158 return NEW_LINE + getJavaDoc(ENUM_ATTRIBUTE, name, false, pluginConfig)
159 + EIGHT_SPACE_INDENTATION + getEnumJavaAttribute(name).toUpperCase() + OPEN_PARENTHESIS
Bharat saraswal250a7472016-05-12 13:16:57 +0530160 + value + CLOSE_PARENTHESIS + COMMA + NEW_LINE;
Bharat saraswal68fa0d12016-04-19 01:00:16 +0530161 }
162
Bharat saraswald14cbe82016-07-14 13:26:18 +0530163 /**
Bharat saraswald14cbe82016-07-14 13:26:18 +0530164 * Returns sorted import list.
165 *
166 * @param imports import list
167 * @return sorted import list
168 */
169 public static List<String> sortImports(List<String> imports) {
170 sort(imports);
171 return imports;
172 }
173
174 /**
175 * Returns event enum start.
176 *
177 * @return event enum start
178 */
Bharat saraswal64e7e232016-07-14 23:33:55 +0530179 static String getEventEnumTypeStart() {
Bharat saraswald14cbe82016-07-14 13:26:18 +0530180 return FOUR_SPACE_INDENTATION + PUBLIC + SPACE + ENUM + SPACE + TYPE + SPACE + OPEN_CURLY_BRACKET
181 + NEW_LINE;
182 }
183
184 /**
185 * Adds listener's imports.
186 *
187 * @param curNode currentYangNode.
188 * @param imports import list
189 * @param operation add or remove
190 * @param classInfo class info to be added to import list
191 */
192 public static void addListenersImport(YangNode curNode, List<String> imports, boolean operation,
193 String classInfo) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530194 String thisImport;
Bharat saraswalaf413b82016-07-14 15:18:20 +0530195 TempJavaServiceFragmentFiles tempJavaServiceFragmentFiles = ((JavaCodeGeneratorInfo) curNode)
196 .getTempJavaCodeFragmentFiles().getServiceTempFiles();
Bharat saraswald14cbe82016-07-14 13:26:18 +0530197 if (classInfo.equals(LISTENER_SERVICE)) {
Bharat saraswalaf413b82016-07-14 15:18:20 +0530198 thisImport = tempJavaServiceFragmentFiles.getJavaImportData().getListenerServiceImport();
Bharat saraswald14cbe82016-07-14 13:26:18 +0530199 performOperationOnImports(imports, thisImport, operation);
200 } else {
Bharat saraswalaf413b82016-07-14 15:18:20 +0530201 thisImport = tempJavaServiceFragmentFiles.getJavaImportData().getListenerRegistryImport();
Bharat saraswald14cbe82016-07-14 13:26:18 +0530202 performOperationOnImports(imports, thisImport, operation);
203 }
204 }
205
206 /**
207 * Performs given operations on import list.
208 *
209 * @param imports list of imports
210 * @param curImport current import
211 * @param operation add or remove
212 * @return import list
213 */
214 private static List<String> performOperationOnImports(List<String> imports, String curImport,
215 boolean operation) {
216 if (operation) {
217 imports.add(curImport);
218 } else {
219 imports.remove(curImport);
220 }
221 sortImports(imports);
222 return imports;
223 }
224
225 /**
Bharat saraswald14cbe82016-07-14 13:26:18 +0530226 * Returns integer attribute for enum's class to get the values.
227 *
228 * @param className enum's class name
229 * @return enum's attribute
230 */
Bharat saraswal64e7e232016-07-14 23:33:55 +0530231 static String getEnumsValueAttribute(String className) {
Bharat saraswald14cbe82016-07-14 13:26:18 +0530232 return NEW_LINE + FOUR_SPACE_INDENTATION + PRIVATE + SPACE + INT + SPACE + getSmallCase(className)
233 + SEMI_COLAN + NEW_LINE;
234 }
235
236 /**
Bharat saraswalaf413b82016-07-14 15:18:20 +0530237 * Returns attribute for augmentation.
238 *
239 * @return attribute for augmentation
240 */
Bharat saraswal64e7e232016-07-14 23:33:55 +0530241 static String addAugmentationAttribute() {
Bharat saraswalaf413b82016-07-14 15:18:20 +0530242 return NEW_LINE + FOUR_SPACE_INDENTATION + PRIVATE + SPACE + MAP + DIAMOND_OPEN_BRACKET + CLASS_STRING
Bharat saraswal8beac342016-08-04 02:00:03 +0530243 + DIAMOND_OPEN_BRACKET + QUESTION_MARK + DIAMOND_CLOSE_BRACKET + COMMA + SPACE + OBJECT_STRING
Bharat saraswalaf413b82016-07-14 15:18:20 +0530244 + DIAMOND_CLOSE_BRACKET + SPACE + getSmallCase(YANG_AUGMENTED_INFO) + MAP + SPACE + EQUAL + SPACE +
245 NEW + SPACE + HASH_MAP + DIAMOND_OPEN_BRACKET + DIAMOND_CLOSE_BRACKET + OPEN_PARENTHESIS
246 + CLOSE_PARENTHESIS + SEMI_COLAN;
247 }
Bharat saraswal64e7e232016-07-14 23:33:55 +0530248
249 /**
250 * Adds attribute for int ranges.
251 *
252 * @param modifier modifier for attribute
253 * @param addFirst true if int need to be added fist.
254 * @return attribute for int ranges
255 */
256 static String addStaticAttributeIntRange(String modifier, boolean addFirst) {
257 if (addFirst) {
258 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + INT_MIN_RANGE_ATTR + FOUR_SPACE_INDENTATION +
259 modifier +
260 SPACE + INT_MAX_RANGE_ATTR;
261 } else {
262 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + UINT_MIN_RANGE_ATTR + FOUR_SPACE_INDENTATION +
263 modifier + SPACE + UINT_MAX_RANGE_ATTR;
264 }
265 }
266
267 /**
268 * Adds attribute for long ranges.
269 *
270 * @param modifier modifier for attribute
271 * @param addFirst if need to be added first
272 * @return attribute for long ranges
273 */
274 static String addStaticAttributeLongRange(String modifier, boolean addFirst) {
275 if (addFirst) {
276 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + LONG_MIN_RANGE_ATTR + FOUR_SPACE_INDENTATION +
277 modifier + SPACE + LONG_MAX_RANGE_ATTR;
278 } else {
279 return NEW_LINE + FOUR_SPACE_INDENTATION + modifier + SPACE + ULONG_MIN_RANGE_ATTR +
280 FOUR_SPACE_INDENTATION + modifier + SPACE + ULONG_MAX_RANGE_ATTR;
281 }
282 }
Bharat saraswal8beac342016-08-04 02:00:03 +0530283
284 /**
285 * Returns operation type enum.
286 *
287 * @return operation type enum
288 */
289 static String getOperationTypeEnum() {
290 return "\n" +
291 " /**\n" +
292 " * Specify the node specific operation in protocols like NETCONF.\n" +
293 " * Applicable in protocol edit operation, not applicable in query operation\n" +
294 " */\n" +
295 " public enum OperationType {\n" +
296 " MERGE,\n" +
297 " REPLACE,\n" +
298 " CREATE,\n" +
299 " DELETE,\n" +
300 " REMOVE\n" +
301 " }\n";
302 }
303
304 /**
305 * Returns operation type enum, leaf value set attribute and select leaf attribute.
306 *
307 * @return operation type enum, leaf value set attribute and select leaf attribute.
308 */
309 static String getOperationAttributes() {
310 return " /**\n" +
311 " * Identify the leafs whose value are explicitly set\n" +
312 " * Applicable in protocol edit and query operation\n" +
313 " */\n" +
314 " private BitSet _valueLeafFlags = new BitSet();\n" +
315 "\n" +
316 " /**\n" +
317 " * Identify the leafs to be selected, in a query operation\n" +
318 " */\n" +
319 " private BitSet _selectLeafFlags = new BitSet();\n";
320 }
321
322 /**
323 * Returns operation type enum, leaf value set attribute and select leaf attribute.
324 *
325 * @return operation type enum, leaf value set attribute and select leaf attribute.
326 */
327 static String getOperationTypeAttr() {
328 return "\n /**\n" +
329 " * Specify the node specific operation in protocols like NETCONF.\n" +
330 " * Applicable in protocol edit operation, will be ignored in query operation\n" +
331 " */\n" +
332 " private OperationType _operationType;\n" +
333 "\n";
334 }
335
336 /**
337 * Returns operation type enum, leaf value set attribute and select leaf attribute for constructor.
338 *
339 * @return operation type enum, leaf value set attribute and select leaf attribute for constructor
340 */
341 static String getOperationAttributeForConstructor() {
342 return " this._valueLeafFlags = builderObject.get_valueLeafFlags();\n" +
343 " this._selectLeafFlags = builderObject.get_selectLeafFlags();\n";
344 }
345
346 /**
347 * Returns operation type enum, leaf value set attribute and select leaf attribute for constructor.
348 *
349 * @return operation type enum, leaf value set attribute and select leaf attribute for constructor
350 */
351 static String getOperationTypeForConstructor() {
352 return " this._operationType = builderObject.get_operationType();\n";
353 }
354
Bharat saraswal97459962016-02-20 21:57:16 +0530355}