Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 1 | /* |
Brian O'Connor | 0f7908b | 2016-04-09 01:19:45 -0700 | [diff] [blame] | 2 | * Copyright 2016-present Open Networking Laboratory |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 3 | * |
| 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 | |
| 17 | package org.onosproject.yangutils.translator.tojava.utils; |
| 18 | |
Vidyashree Rama | b367047 | 2016-08-06 15:49:56 +0530 | [diff] [blame] | 19 | import org.onosproject.yangutils.datamodel.YangCompilerAnnotation; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 20 | import org.onosproject.yangutils.datamodel.YangNode; |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 21 | import org.onosproject.yangutils.translator.exception.TranslatorException; |
Bharat saraswal | af413b8 | 2016-07-14 15:18:20 +0530 | [diff] [blame] | 22 | import org.onosproject.yangutils.translator.tojava.JavaCodeGeneratorInfo; |
Shankara-Huawei | b756477 | 2016-08-02 18:13:13 +0530 | [diff] [blame] | 23 | import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfoTranslator; |
Bharat saraswal | af413b8 | 2016-07-14 15:18:20 +0530 | [diff] [blame] | 24 | import org.onosproject.yangutils.translator.tojava.TempJavaServiceFragmentFiles; |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 25 | import org.onosproject.yangutils.utils.UtilConstants.Operation; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 26 | |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 27 | import java.util.List; |
| 28 | |
| 29 | import static java.util.Collections.sort; |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 30 | import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getEnumJavaAttribute; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 31 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getDefaultDefinition; |
| 32 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getImportString; |
Bharat saraswal | 0663aff | 2016-10-18 23:16:14 +0530 | [diff] [blame^] | 33 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getOpenCloseParaWithValue; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 34 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.signatureClose; |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 35 | import static org.onosproject.yangutils.utils.UtilConstants.BIT_SET; |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 36 | import static org.onosproject.yangutils.utils.UtilConstants.COMMA; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 37 | import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_CLOSE_BRACKET; |
| 38 | import static org.onosproject.yangutils.utils.UtilConstants.DIAMOND_OPEN_BRACKET; |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 39 | import static org.onosproject.yangutils.utils.UtilConstants.EIGHT_SPACE_INDENTATION; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 40 | import static org.onosproject.yangutils.utils.UtilConstants.EMPTY_STRING; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 41 | import static org.onosproject.yangutils.utils.UtilConstants.ENUM; |
Bharat saraswal | e2bc60d | 2016-04-16 02:28:25 +0530 | [diff] [blame] | 42 | import static org.onosproject.yangutils.utils.UtilConstants.EQUAL; |
| 43 | import static org.onosproject.yangutils.utils.UtilConstants.FOUR_SPACE_INDENTATION; |
Bharat saraswal | af413b8 | 2016-07-14 15:18:20 +0530 | [diff] [blame] | 44 | import static org.onosproject.yangutils.utils.UtilConstants.HASH_MAP; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 45 | import static org.onosproject.yangutils.utils.UtilConstants.INT; |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 46 | import static org.onosproject.yangutils.utils.UtilConstants.INT_MAX_RANGE_ATTR; |
| 47 | import static org.onosproject.yangutils.utils.UtilConstants.INT_MIN_RANGE_ATTR; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 48 | import static org.onosproject.yangutils.utils.UtilConstants.LIST; |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 49 | import static org.onosproject.yangutils.utils.UtilConstants.LONG_MAX_RANGE_ATTR; |
| 50 | import static org.onosproject.yangutils.utils.UtilConstants.LONG_MIN_RANGE_ATTR; |
Bharat saraswal | af413b8 | 2016-07-14 15:18:20 +0530 | [diff] [blame] | 51 | import static org.onosproject.yangutils.utils.UtilConstants.NEW; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 52 | import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE; |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 53 | import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CLOSE_BRACKET_STRING; |
Bharat saraswal | 94844d6 | 2016-10-13 13:28:03 +0530 | [diff] [blame] | 54 | import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CLOSE_DIAMOND_STRING; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 55 | import static org.onosproject.yangutils.utils.UtilConstants.PERIOD; |
| 56 | import static org.onosproject.yangutils.utils.UtilConstants.PRIVATE; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 57 | import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC; |
Vidyashree Rama | b367047 | 2016-08-06 15:49:56 +0530 | [diff] [blame] | 58 | import static org.onosproject.yangutils.utils.UtilConstants.QUEUE; |
Bharat saraswal | 748fc3c | 2016-09-06 16:38:20 +0530 | [diff] [blame] | 59 | import static org.onosproject.yangutils.utils.UtilConstants.QUOTES; |
| 60 | import static org.onosproject.yangutils.utils.UtilConstants.SCHEMA_NAME; |
Bharat saraswal | 94844d6 | 2016-10-13 13:28:03 +0530 | [diff] [blame] | 61 | import static org.onosproject.yangutils.utils.UtilConstants.SELECT_LEAF; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 62 | import static org.onosproject.yangutils.utils.UtilConstants.SEMI_COLON; |
Vidyashree Rama | b367047 | 2016-08-06 15:49:56 +0530 | [diff] [blame] | 63 | import static org.onosproject.yangutils.utils.UtilConstants.SET; |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 64 | import static org.onosproject.yangutils.utils.UtilConstants.SET_VALUE_PARA; |
Bharat saraswal | 2da23bf | 2016-08-25 15:28:39 +0530 | [diff] [blame] | 65 | import static org.onosproject.yangutils.utils.UtilConstants.SHORT_MAX_RANGE_ATTR; |
| 66 | import static org.onosproject.yangutils.utils.UtilConstants.SHORT_MIN_RANGE_ATTR; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 67 | import static org.onosproject.yangutils.utils.UtilConstants.SPACE; |
Bharat saraswal | 748fc3c | 2016-09-06 16:38:20 +0530 | [diff] [blame] | 68 | import static org.onosproject.yangutils.utils.UtilConstants.STRING_DATA_TYPE; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 69 | import static org.onosproject.yangutils.utils.UtilConstants.TYPE; |
Bharat saraswal | 2da23bf | 2016-08-25 15:28:39 +0530 | [diff] [blame] | 70 | import static org.onosproject.yangutils.utils.UtilConstants.UINT8_MAX_RANGE_ATTR; |
| 71 | import static org.onosproject.yangutils.utils.UtilConstants.UINT8_MIN_RANGE_ATTR; |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 72 | import static org.onosproject.yangutils.utils.UtilConstants.UINT_MAX_RANGE_ATTR; |
| 73 | import static org.onosproject.yangutils.utils.UtilConstants.UINT_MIN_RANGE_ATTR; |
| 74 | import static org.onosproject.yangutils.utils.UtilConstants.ULONG_MAX_RANGE_ATTR; |
| 75 | import static org.onosproject.yangutils.utils.UtilConstants.ULONG_MIN_RANGE_ATTR; |
Bharat saraswal | 94844d6 | 2016-10-13 13:28:03 +0530 | [diff] [blame] | 76 | import static org.onosproject.yangutils.utils.UtilConstants.VALUE_LEAF; |
| 77 | import static org.onosproject.yangutils.utils.UtilConstants.YANG_AUGMENTED_INFO_MAP; |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 78 | import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.ENUM_ATTRIBUTE; |
Bharat saraswal | 748fc3c | 2016-09-06 16:38:20 +0530 | [diff] [blame] | 79 | import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.enumJavaDocForInnerClass; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 80 | import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.getJavaDoc; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 81 | import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.trimAtLast; |
VinodKumarS-Huawei | 8f16422 | 2016-08-31 15:47:30 +0530 | [diff] [blame] | 82 | |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 83 | /** |
Bharat saraswal | 63f26fb | 2016-04-05 15:13:44 +0530 | [diff] [blame] | 84 | * Represents utility class to generate the java snippet. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 85 | */ |
| 86 | public final class JavaCodeSnippetGen { |
| 87 | |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 88 | // No instantiation. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 89 | private JavaCodeSnippetGen() { |
| 90 | } |
| 91 | |
| 92 | /** |
Bharat saraswal | 63f26fb | 2016-04-05 15:13:44 +0530 | [diff] [blame] | 93 | * Returns the java file header comment. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 94 | * |
Vinod Kumar S | 0871098 | 2016-03-03 19:55:30 +0530 | [diff] [blame] | 95 | * @return the java file header comment |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 96 | */ |
| 97 | public static String getFileHeaderComment() { |
| 98 | |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 99 | /* |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 100 | * TODO return the file header. |
| 101 | */ |
| 102 | return null; |
| 103 | } |
| 104 | |
| 105 | /** |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 106 | * Returns the textual java code information corresponding to the import |
| 107 | * list. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 108 | * |
Vinod Kumar S | 0871098 | 2016-03-03 19:55:30 +0530 | [diff] [blame] | 109 | * @param importInfo import info |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 110 | * @return the textual java code information corresponding to the import |
| 111 | * list |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 112 | */ |
Shankara-Huawei | b756477 | 2016-08-02 18:13:13 +0530 | [diff] [blame] | 113 | static String getImportText(JavaQualifiedTypeInfoTranslator importInfo) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 114 | return getImportString(importInfo.getPkgInfo(), importInfo |
| 115 | .getClassInfo()); |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 116 | } |
| 117 | |
| 118 | /** |
Bharat saraswal | 63f26fb | 2016-04-05 15:13:44 +0530 | [diff] [blame] | 119 | * Returns the textual java code for attribute definition in class. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 120 | * |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 121 | * @param typePkg Package of the attribute type |
| 122 | * @param attrType java attribute type |
| 123 | * @param attrName name of the attribute |
| 124 | * @param isList is list attribute |
| 125 | * @param accessType attribute access type |
| 126 | * @param annotation compiler annotation |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 127 | * @return the textual java code for attribute definition in class |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 128 | */ |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 129 | public static String getJavaAttributeDefinition(String typePkg, |
| 130 | String attrType, |
| 131 | String attrName, |
| 132 | boolean isList, |
| 133 | String accessType, |
| 134 | YangCompilerAnnotation annotation) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 135 | StringBuilder attrDef = new StringBuilder(FOUR_SPACE_INDENTATION); |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 136 | attrDef.append(accessType).append(SPACE); |
Vinod Kumar S | 0871098 | 2016-03-03 19:55:30 +0530 | [diff] [blame] | 137 | |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 138 | if (!isList) { |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 139 | if (typePkg != null) { |
| 140 | attrDef.append(typePkg).append(PERIOD); |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 141 | } |
| 142 | |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 143 | attrDef.append(attrType).append(SPACE) |
Bharat saraswal | 94844d6 | 2016-10-13 13:28:03 +0530 | [diff] [blame] | 144 | .append(attrName); |
| 145 | //Initialize select leaf/value leaf/ augment map attribute. |
| 146 | if (attrName.equals(SELECT_LEAF) || attrName.equals(VALUE_LEAF)) { |
| 147 | attrDef.append(SPACE).append(EQUAL).append(SPACE).append(NEW) |
| 148 | .append(SPACE).append(BIT_SET) |
| 149 | .append(OPEN_CLOSE_BRACKET_STRING); |
| 150 | } else if (attrName.equals(YANG_AUGMENTED_INFO_MAP)) { |
| 151 | attrDef.append(SPACE).append(EQUAL).append(SPACE).append(NEW) |
| 152 | .append(SPACE).append(HASH_MAP) |
| 153 | .append(OPEN_CLOSE_DIAMOND_STRING) |
| 154 | .append(OPEN_CLOSE_BRACKET_STRING); |
| 155 | } |
| 156 | |
| 157 | attrDef.append(signatureClose()); |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 158 | } else { |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 159 | // Add starting definition. |
| 160 | addAttrStartDef(annotation, attrDef); |
| 161 | |
| 162 | if (typePkg != null) { |
| 163 | attrDef.append(typePkg).append(PERIOD); |
Vidyashree Rama | b367047 | 2016-08-06 15:49:56 +0530 | [diff] [blame] | 164 | } |
| 165 | |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 166 | attrDef.append(attrType); |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 167 | |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 168 | // Add ending definition. |
Bharat saraswal | 0663aff | 2016-10-18 23:16:14 +0530 | [diff] [blame^] | 169 | addAttrEndDef(attrDef, attrName); |
Bharat saraswal | 5e3c45c | 2016-02-22 22:15:21 +0530 | [diff] [blame] | 170 | } |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 171 | return attrDef.toString(); |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 172 | } |
| 173 | |
| 174 | /** |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 175 | * Adds starting attribute definition. |
| 176 | * |
| 177 | * @param annotation compiler annotation |
| 178 | * @param attrDef JAVA attribute definition |
| 179 | */ |
| 180 | private static void addAttrStartDef(YangCompilerAnnotation annotation, |
| 181 | StringBuilder attrDef) { |
| 182 | if (annotation != null && |
| 183 | annotation.getYangAppDataStructure() != null) { |
| 184 | switch (annotation.getYangAppDataStructure().getDataStructure()) { |
| 185 | case QUEUE: { |
| 186 | attrDef.append(QUEUE) |
| 187 | .append(DIAMOND_OPEN_BRACKET); |
| 188 | break; |
| 189 | } |
| 190 | case SET: { |
| 191 | attrDef.append(SET) |
| 192 | .append(DIAMOND_OPEN_BRACKET); |
| 193 | break; |
| 194 | } |
| 195 | default: { |
| 196 | attrDef.append(LIST) |
| 197 | .append(DIAMOND_OPEN_BRACKET); |
| 198 | } |
| 199 | } |
| 200 | } else { |
| 201 | attrDef.append(LIST).append(DIAMOND_OPEN_BRACKET); |
| 202 | } |
| 203 | } |
| 204 | |
| 205 | /** |
| 206 | * Adds ending attribute definition. |
| 207 | * |
Bharat saraswal | 0663aff | 2016-10-18 23:16:14 +0530 | [diff] [blame^] | 208 | * @param attrDef JAVA attribute definition |
| 209 | * @param attrName name of attribute |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 210 | */ |
Bharat saraswal | 0663aff | 2016-10-18 23:16:14 +0530 | [diff] [blame^] | 211 | private static void addAttrEndDef(StringBuilder attrDef, String attrName) { |
| 212 | attrDef.append(DIAMOND_CLOSE_BRACKET).append(SPACE) |
| 213 | .append(attrName).append(signatureClose()); |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 214 | } |
| 215 | |
| 216 | /** |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 217 | * Returns string for enum's attribute. |
| 218 | * |
Bharat saraswal | 748fc3c | 2016-09-06 16:38:20 +0530 | [diff] [blame] | 219 | * @param name name of attribute |
| 220 | * @param value value of the enum |
| 221 | * @return string for enum's attribute |
| 222 | */ |
| 223 | public static String generateEnumAttributeString(String name, int value) { |
| 224 | String enumName = getEnumJavaAttribute(name); |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 225 | return enumJavaDocForInnerClass(name) + EIGHT_SPACE_INDENTATION + |
Bharat saraswal | 0663aff | 2016-10-18 23:16:14 +0530 | [diff] [blame^] | 226 | enumName.toUpperCase() + getOpenCloseParaWithValue( |
| 227 | value + EMPTY_STRING) + COMMA + NEW_LINE; |
Bharat saraswal | 748fc3c | 2016-09-06 16:38:20 +0530 | [diff] [blame] | 228 | } |
| 229 | |
| 230 | /** |
| 231 | * Returns string for enum's attribute for enum class. |
| 232 | * |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 233 | * @param name name of attribute |
| 234 | * @param value value of the enum |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 235 | * @return string for enum's attribute |
| 236 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 237 | public static String generateEnumAttributeStringWithSchemaName( |
| 238 | String name, int value) { |
Bharat saraswal | 748fc3c | 2016-09-06 16:38:20 +0530 | [diff] [blame] | 239 | String enumName = getEnumJavaAttribute(name); |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 240 | String str = value + COMMA + SPACE + QUOTES + name + QUOTES; |
| 241 | return getJavaDoc(ENUM_ATTRIBUTE, name, false, null) + |
Bharat saraswal | 0663aff | 2016-10-18 23:16:14 +0530 | [diff] [blame^] | 242 | FOUR_SPACE_INDENTATION + enumName.toUpperCase() + |
| 243 | getOpenCloseParaWithValue(str) + COMMA + NEW_LINE; |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 244 | } |
| 245 | |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 246 | /** |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 247 | * Returns sorted import list. |
| 248 | * |
| 249 | * @param imports import list |
| 250 | * @return sorted import list |
| 251 | */ |
| 252 | public static List<String> sortImports(List<String> imports) { |
| 253 | sort(imports); |
| 254 | return imports; |
| 255 | } |
| 256 | |
| 257 | /** |
| 258 | * Returns event enum start. |
| 259 | * |
| 260 | * @return event enum start |
| 261 | */ |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 262 | static String getEventEnumTypeStart() { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 263 | return NEW_LINE + FOUR_SPACE_INDENTATION + |
| 264 | getDefaultDefinition(ENUM, TYPE, PUBLIC); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 265 | } |
| 266 | |
| 267 | /** |
| 268 | * Adds listener's imports. |
| 269 | * |
| 270 | * @param curNode currentYangNode. |
| 271 | * @param imports import list |
| 272 | * @param operation add or remove |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 273 | */ |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 274 | public static void addListenersImport(YangNode curNode, |
| 275 | List<String> imports, |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 276 | Operation operation) { |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 277 | String thisImport; |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 278 | TempJavaServiceFragmentFiles tempFiles = |
| 279 | ((JavaCodeGeneratorInfo) curNode).getTempJavaCodeFragmentFiles() |
| 280 | .getServiceTempFiles(); |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 281 | thisImport = tempFiles.getJavaImportData().getListenerServiceImport(); |
| 282 | performOperationOnImports(imports, thisImport, operation); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 283 | } |
| 284 | |
| 285 | /** |
| 286 | * Performs given operations on import list. |
| 287 | * |
| 288 | * @param imports list of imports |
| 289 | * @param curImport current import |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 290 | * @param operation ADD or REMOVE |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 291 | * @return import list |
| 292 | */ |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 293 | private static List<String> performOperationOnImports(List<String> imports, |
| 294 | String curImport, |
| 295 | Operation operation) { |
| 296 | switch (operation) { |
| 297 | case ADD: |
| 298 | imports.add(curImport); |
| 299 | break; |
| 300 | case REMOVE: |
| 301 | imports.remove(curImport); |
| 302 | break; |
| 303 | default: |
| 304 | throw new TranslatorException("Invalid operation type"); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 305 | } |
| 306 | sortImports(imports); |
| 307 | return imports; |
| 308 | } |
| 309 | |
| 310 | /** |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 311 | * Returns integer attribute for enum's class to get the values. |
| 312 | * |
| 313 | * @param className enum's class name |
| 314 | * @return enum's attribute |
| 315 | */ |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 316 | static String getEnumsValueAttribute(String className) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 317 | return getJavaAttributeDefinition(null, INT, className, |
| 318 | false, PRIVATE, null) + |
| 319 | getJavaAttributeDefinition(null, STRING_DATA_TYPE, SCHEMA_NAME, |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 320 | false, PRIVATE, null) + NEW_LINE; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 321 | } |
| 322 | |
| 323 | /** |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 324 | * Adds attribute for int ranges. |
| 325 | * |
| 326 | * @param modifier modifier for attribute |
| 327 | * @param addFirst true if int need to be added fist. |
| 328 | * @return attribute for int ranges |
| 329 | */ |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 330 | static String addStaticAttributeIntRange(String modifier, |
| 331 | boolean addFirst) { |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 332 | if (addFirst) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 333 | return getTypeConflictAttributeStrings(modifier, |
| 334 | INT_MIN_RANGE_ATTR, |
| 335 | INT_MAX_RANGE_ATTR); |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 336 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 337 | return getTypeConflictAttributeStrings(modifier, |
| 338 | UINT_MIN_RANGE_ATTR, |
| 339 | UINT_MAX_RANGE_ATTR); |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 340 | } |
| 341 | |
| 342 | /** |
| 343 | * Adds attribute for long ranges. |
| 344 | * |
| 345 | * @param modifier modifier for attribute |
| 346 | * @param addFirst if need to be added first |
| 347 | * @return attribute for long ranges |
| 348 | */ |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 349 | static String addStaticAttributeLongRange(String modifier, |
| 350 | boolean addFirst) { |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 351 | if (addFirst) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 352 | return getTypeConflictAttributeStrings(modifier, |
| 353 | LONG_MIN_RANGE_ATTR, |
| 354 | LONG_MAX_RANGE_ATTR); |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 355 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 356 | return getTypeConflictAttributeStrings(modifier, |
| 357 | ULONG_MIN_RANGE_ATTR, |
| 358 | ULONG_MAX_RANGE_ATTR); |
Bharat saraswal | 64e7e23 | 2016-07-14 23:33:55 +0530 | [diff] [blame] | 359 | } |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 360 | |
| 361 | /** |
Bharat saraswal | 2da23bf | 2016-08-25 15:28:39 +0530 | [diff] [blame] | 362 | * Adds attribute for long ranges. |
| 363 | * |
| 364 | * @param modifier modifier for attribute |
| 365 | * @param addFirst if need to be added first |
| 366 | * @return attribute for long ranges |
| 367 | */ |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 368 | static String addStaticAttributeShortRange(String modifier, |
| 369 | boolean addFirst) { |
Bharat saraswal | 2da23bf | 2016-08-25 15:28:39 +0530 | [diff] [blame] | 370 | if (addFirst) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 371 | return getTypeConflictAttributeStrings(modifier, |
| 372 | SHORT_MIN_RANGE_ATTR, |
| 373 | SHORT_MAX_RANGE_ATTR); |
Bharat saraswal | 2da23bf | 2016-08-25 15:28:39 +0530 | [diff] [blame] | 374 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 375 | return getTypeConflictAttributeStrings(modifier, |
| 376 | UINT8_MIN_RANGE_ATTR, |
| 377 | UINT8_MAX_RANGE_ATTR); |
| 378 | } |
| 379 | |
| 380 | /** |
| 381 | * Returns attribute for conflicting type in union. |
| 382 | * |
| 383 | * @param modifier modifier |
| 384 | * @param attr1 attribute one |
| 385 | * @param att2 attribute two |
| 386 | * @return attribute for conflicting type in union |
| 387 | */ |
| 388 | private static String getTypeConflictAttributeStrings(String modifier, |
| 389 | String attr1, |
| 390 | String att2) { |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 391 | return FOUR_SPACE_INDENTATION + modifier + SPACE + |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 392 | attr1 + FOUR_SPACE_INDENTATION + modifier + |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 393 | SPACE + att2 + NEW_LINE; |
Bharat saraswal | 2da23bf | 2016-08-25 15:28:39 +0530 | [diff] [blame] | 394 | } |
| 395 | |
| 396 | /** |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 397 | * Returns operation type enum. |
| 398 | * |
| 399 | * @return operation type enum |
| 400 | */ |
| 401 | static String getOperationTypeEnum() { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 402 | return " /**\n" + |
| 403 | " * Specify the node specific operation in protocols " + |
| 404 | "like NETCONF.\n" + |
| 405 | " * Applicable in protocol edit operation, not applicable" + |
| 406 | " in query operation\n" + |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 407 | " */\n" + |
Bharat saraswal | 94844d6 | 2016-10-13 13:28:03 +0530 | [diff] [blame] | 408 | " public static enum OnosYangOpType {\n" + |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 409 | " MERGE,\n" + |
| 410 | " REPLACE,\n" + |
| 411 | " CREATE,\n" + |
| 412 | " DELETE,\n" + |
VinodKumarS-Huawei | 8f16422 | 2016-08-31 15:47:30 +0530 | [diff] [blame] | 413 | " REMOVE,\n" + |
| 414 | " NONE\n" + |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 415 | " }\n"; |
| 416 | } |
| 417 | |
| 418 | /** |
Bharat saraswal | e3175d3 | 2016-08-31 17:50:11 +0530 | [diff] [blame] | 419 | * Returns attribute in constructor for yang augmented info map. |
| 420 | * |
Gaurav Agrawal | 3b57f36 | 2016-09-07 13:16:35 +0530 | [diff] [blame] | 421 | * @return augment info map |
Bharat saraswal | e3175d3 | 2016-08-31 17:50:11 +0530 | [diff] [blame] | 422 | */ |
| 423 | static String getYangAugmentedMapObjectForConstruct() { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame] | 424 | return " this.yangAugmentedInfoMap = builderObject" + |
| 425 | ".yangAugmentedInfoMap();\n"; |
Bharat saraswal | e3175d3 | 2016-08-31 17:50:11 +0530 | [diff] [blame] | 426 | } |
Bharat saraswal | 54e4bab | 2016-10-05 23:32:14 +0530 | [diff] [blame] | 427 | |
| 428 | /** |
| 429 | * Returns set value parameter for union class. |
| 430 | * |
| 431 | * @return set value parameter for union class. |
| 432 | */ |
| 433 | static String getSetValueParaForUnionClass() { |
| 434 | String[] array = {NEW_LINE, SEMI_COLON}; |
| 435 | return new StringBuilder().append(trimAtLast( |
| 436 | getJavaAttributeDefinition(null, BIT_SET, SET_VALUE_PARA, |
| 437 | false, PRIVATE, null), array)) |
| 438 | .append(SPACE).append(EQUAL).append(SPACE).append(NEW) |
| 439 | .append(SPACE).append(BIT_SET).append(OPEN_CLOSE_BRACKET_STRING) |
| 440 | .append(signatureClose()).toString(); |
| 441 | } |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 442 | } |