blob: d29fb8658478c5007c17feedf4505197d5920990 [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;
Vinod Kumar S38046502016-03-23 15:30:27 +053022import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053023import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFiles;
24import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFilesContainer;
25import org.onosproject.yangutils.translator.tojava.TempJavaFragmentFiles;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053026import org.onosproject.yangutils.utils.io.impl.YangPluginConfig;
Bharat saraswale2d51d62016-03-23 19:40:35 +053027
Bharat saraswald72411a2016-04-19 01:00:16 +053028import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getEnumJavaAttribute;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053029import static org.onosproject.yangutils.utils.UtilConstants.ACTIVATE_ANNOTATION_IMPORT;
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 saraswalb1170bd2016-07-14 13:26:18 +053041import static org.onosproject.yangutils.utils.UtilConstants.IMMEDIATE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053042import static org.onosproject.yangutils.utils.UtilConstants.IMPORT;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053043import static org.onosproject.yangutils.utils.UtilConstants.INT;
Bharat saraswale2d51d62016-03-23 19:40:35 +053044import static org.onosproject.yangutils.utils.UtilConstants.LIST;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053045import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_SERVICE;
46import static org.onosproject.yangutils.utils.UtilConstants.LOGGER_FACTORY_IMPORT;
47import static org.onosproject.yangutils.utils.UtilConstants.LOGGER_IMPORT;
Bharat saraswale2d51d62016-03-23 19:40:35 +053048import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053049import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053050import static org.onosproject.yangutils.utils.UtilConstants.OPEN_PARENTHESIS;
Bharat saraswale2d51d62016-03-23 19:40:35 +053051import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
52import static org.onosproject.yangutils.utils.UtilConstants.PRIVATE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053053import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC;
Bharat saraswale2d51d62016-03-23 19:40:35 +053054import static org.onosproject.yangutils.utils.UtilConstants.SEMI_COLAN;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053055import static org.onosproject.yangutils.utils.UtilConstants.SERVICE_ANNOTATION;
56import static org.onosproject.yangutils.utils.UtilConstants.SERVICE_ANNOTATION_IMPORT;
Bharat saraswale2d51d62016-03-23 19:40:35 +053057import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053058import static org.onosproject.yangutils.utils.UtilConstants.TRUE;
59import static org.onosproject.yangutils.utils.UtilConstants.TYPE;
Bharat saraswald72411a2016-04-19 01:00:16 +053060import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.ENUM_ATTRIBUTE;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053061import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.getJavaDoc;
62import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getSmallCase;
63import static java.util.Collections.sort;
Bharat saraswal870c56f2016-02-20 21:57:16 +053064
65/**
Bharat saraswald9822e92016-04-05 15:13:44 +053066 * Represents utility class to generate the java snippet.
Bharat saraswal870c56f2016-02-20 21:57:16 +053067 */
68public final class JavaCodeSnippetGen {
69
70 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053071 * Creates an instance of java code snippet gen.
Bharat saraswal870c56f2016-02-20 21:57:16 +053072 */
73 private JavaCodeSnippetGen() {
74 }
75
76 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053077 * Returns the java file header comment.
Bharat saraswal870c56f2016-02-20 21:57:16 +053078 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +053079 * @return the java file header comment
Bharat saraswal870c56f2016-02-20 21:57:16 +053080 */
81 public static String getFileHeaderComment() {
82
83 /**
84 * TODO return the file header.
85 */
86 return null;
87 }
88
89 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053090 * Returns the textual java code information corresponding to the import list.
Bharat saraswal870c56f2016-02-20 21:57:16 +053091 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +053092 * @param importInfo import info
Bharat saraswal870c56f2016-02-20 21:57:16 +053093 * @return the textual java code information corresponding to the import
Bharat saraswalb1170bd2016-07-14 13:26:18 +053094 * list
Bharat saraswal870c56f2016-02-20 21:57:16 +053095 */
Vinod Kumar S38046502016-03-23 15:30:27 +053096 public static String getImportText(JavaQualifiedTypeInfo importInfo) {
Bharat saraswale2d51d62016-03-23 19:40:35 +053097 return IMPORT + importInfo.getPkgInfo() + PERIOD + importInfo.getClassInfo() + SEMI_COLAN + NEW_LINE;
Bharat saraswal870c56f2016-02-20 21:57:16 +053098 }
99
100 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530101 * Returns the textual java code for attribute definition in class.
Bharat saraswal870c56f2016-02-20 21:57:16 +0530102 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530103 * @param javaAttributeTypePkg Package of the attribute type
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530104 * @param javaAttributeType java attribute type
105 * @param javaAttributeName name of the attribute
106 * @param isList is list attribute
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530107 * @return the textual java code for attribute definition in class
Bharat saraswal870c56f2016-02-20 21:57:16 +0530108 */
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530109 public static String getJavaAttributeDefination(String javaAttributeTypePkg, String javaAttributeType,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530110 String javaAttributeName, boolean isList) {
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530111
Bharat saraswale2d51d62016-03-23 19:40:35 +0530112 String attributeDefination = PRIVATE + SPACE;
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530113
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530114 if (!isList) {
115 if (javaAttributeTypePkg != null) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530116 attributeDefination = attributeDefination + javaAttributeTypePkg + PERIOD;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530117 }
118
Bharat saraswale2d51d62016-03-23 19:40:35 +0530119 attributeDefination = attributeDefination + javaAttributeType + SPACE + javaAttributeName + SEMI_COLAN
120 + NEW_LINE;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530121 } else {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530122 attributeDefination = attributeDefination + LIST + DIAMOND_OPEN_BRACKET;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530123 if (javaAttributeTypePkg != null) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530124 attributeDefination = attributeDefination + javaAttributeTypePkg + PERIOD;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530125 }
126
Bharat saraswale2d51d62016-03-23 19:40:35 +0530127 attributeDefination = attributeDefination + javaAttributeType + DIAMOND_CLOSE_BRACKET + SPACE
128 + javaAttributeName + SEMI_COLAN + NEW_LINE;
Bharat saraswal594bc6d2016-02-22 22:15:21 +0530129 }
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530130 return attributeDefination;
Bharat saraswal594bc6d2016-02-22 22:15:21 +0530131 }
132
133 /**
134 * Returns list attribute string.
135 *
136 * @param type attribute type
137 * @return list attribute string
138 */
Bharat saraswalcad0e652016-05-26 23:48:38 +0530139 public static String getListAttribute(String type) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530140 return LIST + DIAMOND_OPEN_BRACKET + type + DIAMOND_CLOSE_BRACKET;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530141 }
142
143 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530144 * Returns based on the file type and the YANG name of the file, generate the class
Bharat saraswal870c56f2016-02-20 21:57:16 +0530145 * / interface definition close.
146 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530147 * @return corresponding textual java code information
Bharat saraswal870c56f2016-02-20 21:57:16 +0530148 */
Vinod Kumar S38046502016-03-23 15:30:27 +0530149 public static String getJavaClassDefClose() {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530150 return CLOSE_CURLY_BRACKET;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530151 }
Bharat saraswald72411a2016-04-19 01:00:16 +0530152
153 /**
154 * Returns string for enum's attribute.
155 *
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530156 * @param name name of attribute
157 * @param value value of the enum
Bharat saraswal33dfa012016-05-17 19:59:16 +0530158 * @param pluginConfig plugin configurations
Bharat saraswald72411a2016-04-19 01:00:16 +0530159 * @return string for enum's attribute
160 */
Bharat saraswal33dfa012016-05-17 19:59:16 +0530161 public static String generateEnumAttributeString(String name, int value, YangPluginConfig pluginConfig) {
162 return getJavaDoc(ENUM_ATTRIBUTE, name, false, pluginConfig) + FOUR_SPACE_INDENTATION
Bharat saraswalc0e04842016-05-12 13:16:57 +0530163 + getEnumJavaAttribute(name).toUpperCase() + OPEN_PARENTHESIS
164 + value + CLOSE_PARENTHESIS + COMMA + NEW_LINE;
Bharat saraswald72411a2016-04-19 01:00:16 +0530165 }
166
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530167 /**
168 * Adds annotations imports.
169 *
170 * @param imports list if imports
171 * @param operation to add or to delete
172 */
173 public static void addAnnotationsImports(List<String> imports, boolean operation) {
174 if (operation) {
175 imports.add(ACTIVATE_ANNOTATION_IMPORT);
176 imports.add(DEACTIVATE_ANNOTATION_IMPORT);
177 imports.add(COMPONENT_ANNOTATION_IMPORT);
178 imports.add(SERVICE_ANNOTATION_IMPORT);
179 imports.add(LOGGER_FACTORY_IMPORT);
180 imports.add(LOGGER_IMPORT);
181 } else {
182 imports.remove(ACTIVATE_ANNOTATION_IMPORT);
183 imports.remove(DEACTIVATE_ANNOTATION_IMPORT);
184 imports.remove(COMPONENT_ANNOTATION_IMPORT);
185 imports.remove(SERVICE_ANNOTATION_IMPORT);
186 imports.remove(LOGGER_FACTORY_IMPORT);
187 imports.remove(LOGGER_IMPORT);
188 }
189 sortImports(imports);
190 }
191
192 /**
193 * Returns sorted import list.
194 *
195 * @param imports import list
196 * @return sorted import list
197 */
198 public static List<String> sortImports(List<String> imports) {
199 sort(imports);
200 return imports;
201 }
202
203 /**
204 * Returns event enum start.
205 *
206 * @return event enum start
207 */
208 public static String getEventEnumTypeStart() {
209 return FOUR_SPACE_INDENTATION + PUBLIC + SPACE + ENUM + SPACE + TYPE + SPACE + OPEN_CURLY_BRACKET
210 + NEW_LINE;
211 }
212
213 /**
214 * Adds listener's imports.
215 *
216 * @param curNode currentYangNode.
217 * @param imports import list
218 * @param operation add or remove
219 * @param classInfo class info to be added to import list
220 */
221 public static void addListenersImport(YangNode curNode, List<String> imports, boolean operation,
222 String classInfo) {
223 String thisImport = "";
224 if (classInfo.equals(LISTENER_SERVICE)) {
225 thisImport = getTempJavaFragment(curNode).getJavaImportData().getListenerServiceImport();
226 performOperationOnImports(imports, thisImport, operation);
227 } else {
228 thisImport = getTempJavaFragment(curNode).getJavaImportData().getListenerRegistryImport();
229 performOperationOnImports(imports, thisImport, operation);
230 }
231 }
232
233 /**
234 * Performs given operations on import list.
235 *
236 * @param imports list of imports
237 * @param curImport current import
238 * @param operation add or remove
239 * @return import list
240 */
241 private static List<String> performOperationOnImports(List<String> imports, String curImport,
242 boolean operation) {
243 if (operation) {
244 imports.add(curImport);
245 } else {
246 imports.remove(curImport);
247 }
248 sortImports(imports);
249 return imports;
250 }
251
252 /**
253 * Returns temp java fragment.
254 *
255 * @param curNode current YANG node
256 * @return temp java fragments
257 */
258 public static TempJavaFragmentFiles getTempJavaFragment(YangNode curNode) {
259 TempJavaCodeFragmentFiles container = ((TempJavaCodeFragmentFilesContainer) curNode)
260 .getTempJavaCodeFragmentFiles();
261 if (container.getBeanTempFiles() != null) {
262 return container.getBeanTempFiles();
263 }
264 if (container.getServiceTempFiles() != null) {
265 return container.getServiceTempFiles();
266 }
267
268 return null;
269 }
270
271 /**
272 * Returns integer attribute for enum's class to get the values.
273 *
274 * @param className enum's class name
275 * @return enum's attribute
276 */
277 public static String getEnumsValueAttribute(String className) {
278 return NEW_LINE + FOUR_SPACE_INDENTATION + PRIVATE + SPACE + INT + SPACE + getSmallCase(className)
279 + SEMI_COLAN + NEW_LINE;
280 }
281
282 /**
283 * Returns component string.
284 *
285 * @return component string
286 */
287 public static String addComponentString() {
288 return NEW_LINE + COMPONENT_ANNOTATION + SPACE + OPEN_PARENTHESIS + IMMEDIATE + SPACE
289 + EQUAL + SPACE + TRUE + CLOSE_PARENTHESIS + NEW_LINE + SERVICE_ANNOTATION;
290 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530291}