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 | |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 19 | import org.onosproject.yangutils.datamodel.RpcNotificationContainer; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 20 | import org.onosproject.yangutils.datamodel.YangAugment; |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 21 | import org.onosproject.yangutils.datamodel.YangCase; |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 22 | import org.onosproject.yangutils.datamodel.YangIdentity; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 23 | import org.onosproject.yangutils.datamodel.YangNode; |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 24 | import org.onosproject.yangutils.datamodel.YangNotification; |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 25 | import org.onosproject.yangutils.translator.exception.TranslatorException; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 26 | import org.onosproject.yangutils.translator.tojava.JavaFileInfoContainer; |
Bharat saraswal | e3175d3 | 2016-08-31 17:50:11 +0530 | [diff] [blame] | 27 | import org.onosproject.yangutils.translator.tojava.JavaFileInfoTranslator; |
Shankara-Huawei | b756477 | 2016-08-02 18:13:13 +0530 | [diff] [blame] | 28 | import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfoTranslator; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 29 | import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFilesContainer; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 30 | |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 31 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_CLASS_MASK; |
| 32 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_INTERFACE_MASK; |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 33 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.DEFAULT_CLASS_MASK; |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 34 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_ENUM_CLASS; |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 35 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_CLASS; |
| 36 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_LISTENER_INTERFACE; |
Bharat saraswal | 715d3fc | 2016-05-17 19:59:16 +0530 | [diff] [blame] | 37 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_SUBJECT_CLASS; |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 38 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_IDENTITY_CLASS; |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 39 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_SERVICE_AND_MANAGER; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 40 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_TYPEDEF_CLASS; |
Gaurav Agrawal | 97a5e1c | 2016-04-18 18:53:11 +0530 | [diff] [blame] | 41 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_UNION_CLASS; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 42 | import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.INTERFACE_MASK; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 43 | import static org.onosproject.yangutils.translator.tojava.utils.BracketType.OPEN_CLOSE_DIAMOND_WITH_VALUE; |
| 44 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.brackets; |
| 45 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getBuilderImplStringClassDef; |
| 46 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getDefaultDefinition; |
| 47 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getDefaultDefinitionWithExtends; |
| 48 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getDefaultDefinitionWithImpl; |
| 49 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getDefaultName; |
| 50 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getErrorMsg; |
| 51 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getEventExtendsString; |
| 52 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getSpecificModifier; |
| 53 | import static org.onosproject.yangutils.translator.tojava.utils.StringGenerator.getSuffixedName; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 54 | import static org.onosproject.yangutils.utils.UtilConstants.ABSTRACT; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 55 | import static org.onosproject.yangutils.utils.UtilConstants.ABSTRACT_EVENT; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 56 | import static org.onosproject.yangutils.utils.UtilConstants.BUILDER; |
| 57 | import static org.onosproject.yangutils.utils.UtilConstants.CLASS; |
Bharat saraswal | e2bc60d | 2016-04-16 02:28:25 +0530 | [diff] [blame] | 58 | import static org.onosproject.yangutils.utils.UtilConstants.COMMA; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 59 | import static org.onosproject.yangutils.utils.UtilConstants.DEFAULT_CAPS; |
| 60 | import static org.onosproject.yangutils.utils.UtilConstants.EMPTY_STRING; |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 61 | import static org.onosproject.yangutils.utils.UtilConstants.ENUM; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 62 | import static org.onosproject.yangutils.utils.UtilConstants.ERROR_MSG_JAVA_IDENTITY; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 63 | import static org.onosproject.yangutils.utils.UtilConstants.EVENT_LISTENER_STRING; |
| 64 | import static org.onosproject.yangutils.utils.UtilConstants.EVENT_STRING; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 65 | import static org.onosproject.yangutils.utils.UtilConstants.EVENT_TYPE; |
Bharat saraswal | e2bc60d | 2016-04-16 02:28:25 +0530 | [diff] [blame] | 66 | import static org.onosproject.yangutils.utils.UtilConstants.EXTEND; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 67 | import static org.onosproject.yangutils.utils.UtilConstants.FINAL; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 68 | import static org.onosproject.yangutils.utils.UtilConstants.IMPLEMENTS; |
| 69 | import static org.onosproject.yangutils.utils.UtilConstants.INTERFACE; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 70 | import static org.onosproject.yangutils.utils.UtilConstants.LISTENER_SERVICE; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 71 | import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE; |
| 72 | import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET; |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 73 | import static org.onosproject.yangutils.utils.UtilConstants.OP_PARAM; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 74 | import static org.onosproject.yangutils.utils.UtilConstants.PERIOD; |
| 75 | import static org.onosproject.yangutils.utils.UtilConstants.PUBLIC; |
janani b | 3e357f6 | 2016-05-19 17:39:50 +0530 | [diff] [blame] | 76 | import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE; |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 77 | import static org.onosproject.yangutils.utils.UtilConstants.SERVICE; |
Bharat saraswal | 84366c5 | 2016-03-23 19:40:35 +0530 | [diff] [blame] | 78 | import static org.onosproject.yangutils.utils.UtilConstants.SPACE; |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 79 | import static org.onosproject.yangutils.utils.UtilConstants.STATIC; |
Bharat saraswal | 715d3fc | 2016-05-17 19:59:16 +0530 | [diff] [blame] | 80 | import static org.onosproject.yangutils.utils.UtilConstants.SUBJECT; |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 81 | import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getCapitalCase; |
Bharat saraswal | e2bc60d | 2016-04-16 02:28:25 +0530 | [diff] [blame] | 82 | import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.trimAtLast; |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 83 | |
| 84 | /** |
Bharat saraswal | 63f26fb | 2016-04-05 15:13:44 +0530 | [diff] [blame] | 85 | * Represents generator for class definition of generated files. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 86 | */ |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 87 | final class ClassDefinitionGenerator { |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 88 | |
| 89 | /** |
Bharat saraswal | 63f26fb | 2016-04-05 15:13:44 +0530 | [diff] [blame] | 90 | * Creates an instance of class definition generator. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 91 | */ |
| 92 | private ClassDefinitionGenerator() { |
| 93 | } |
| 94 | |
| 95 | /** |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 96 | * Based on the file type and the YANG name of the file, generate the class |
| 97 | * / interface definition start. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 98 | * |
| 99 | * @param genFileTypes generated file type |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 100 | * @param yangName class name |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 101 | * @return class definition |
| 102 | */ |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 103 | static String generateClassDefinition(int genFileTypes, String yangName) { |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 104 | |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 105 | /* |
Gaurav Agrawal | 02a60de | 2016-04-20 15:49:17 +0530 | [diff] [blame] | 106 | * Based on the file type and the YANG name of the file, generate the |
Vinod Kumar S | 0871098 | 2016-03-03 19:55:30 +0530 | [diff] [blame] | 107 | * class / interface definition start. |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 108 | */ |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 109 | switch (genFileTypes) { |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 110 | case GENERATE_TYPEDEF_CLASS: |
| 111 | case GENERATE_UNION_CLASS: |
| 112 | return getTypeClassDefinition(yangName); |
| 113 | case GENERATE_ENUM_CLASS: |
| 114 | return getEnumClassDefinition(yangName); |
| 115 | default: |
| 116 | return null; |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 117 | } |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 118 | } |
| 119 | |
| 120 | /** |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 121 | * Based on the file type and the YANG name of the file, generate the class |
| 122 | * / interface definition start. |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 123 | * |
| 124 | * @param genFileTypes generated file type |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 125 | * @param yangName class name |
| 126 | * @param curNode current YANG node |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 127 | * @return class definition |
| 128 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 129 | static String generateClassDefinition(int genFileTypes, String yangName, |
| 130 | YangNode curNode) { |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 131 | /* |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 132 | * Based on the file type and the YANG name of the file, generate the |
| 133 | * class / interface definition start. |
| 134 | */ |
| 135 | switch (genFileTypes) { |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 136 | case INTERFACE_MASK: |
| 137 | return getInterfaceDefinition(yangName, curNode); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 138 | case BUILDER_CLASS_MASK: |
| 139 | return getBuilderClassDefinition(yangName, curNode); |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 140 | case DEFAULT_CLASS_MASK: |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 141 | return getImplClassDefinition(yangName, curNode); |
| 142 | case BUILDER_INTERFACE_MASK: |
| 143 | return getBuilderInterfaceDefinition(yangName, curNode); |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 144 | case GENERATE_SERVICE_AND_MANAGER: |
| 145 | return getRpcInterfaceDefinition(yangName, curNode); |
| 146 | case GENERATE_EVENT_CLASS: |
| 147 | String eventName = yangName + SUBJECT; |
| 148 | return getEventDefinition(yangName, eventName); |
| 149 | case GENERATE_EVENT_LISTENER_INTERFACE: |
| 150 | return getEventListenerDefinition(yangName); |
| 151 | case GENERATE_EVENT_SUBJECT_CLASS: |
| 152 | return getClassDefinition(yangName); |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 153 | case GENERATE_IDENTITY_CLASS: |
| 154 | return getIdentityClassDefinition(yangName, curNode); |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 155 | default: |
| 156 | return null; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 157 | } |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 158 | } |
| 159 | |
| 160 | /** |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 161 | * Returns enum file class definition. |
| 162 | * |
| 163 | * @param yangName class name |
Gaurav Agrawal | 02a60de | 2016-04-20 15:49:17 +0530 | [diff] [blame] | 164 | * @return enum file class definition |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 165 | */ |
| 166 | private static String getEnumClassDefinition(String yangName) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 167 | return getDefaultDefinition(ENUM, yangName, PUBLIC); |
Bharat saraswal | 68fa0d1 | 2016-04-19 01:00:16 +0530 | [diff] [blame] | 168 | } |
| 169 | |
| 170 | /** |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 171 | * Returns interface file class definition. |
| 172 | * |
| 173 | * @param yangName file name |
| 174 | * @return definition |
| 175 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 176 | private static String getInterfaceDefinition(String yangName, |
| 177 | YangNode curNode) { |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 178 | |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 179 | String clsDef = getClassDefinitionForWhenExtended(curNode, yangName, |
| 180 | INTERFACE_MASK); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 181 | if (clsDef != null) { |
| 182 | return clsDef; |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 183 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 184 | return getDefaultDefinition(INTERFACE, yangName, PUBLIC); |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 185 | } |
| 186 | |
| 187 | /** |
| 188 | * Returns builder interface file class definition. |
| 189 | * |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 190 | * @param yangName java class name, corresponding to which the builder |
| 191 | * class is being generated |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 192 | * @return definition |
| 193 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 194 | private static String getBuilderInterfaceDefinition(String yangName, |
| 195 | YangNode curNode) { |
| 196 | if (!(curNode instanceof YangCase) && |
| 197 | !(curNode instanceof YangAugment)) { |
| 198 | String clsDef = getClassDefinitionForWhenExtended( |
| 199 | curNode, yangName, BUILDER_INTERFACE_MASK); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 200 | if (clsDef != null) { |
| 201 | return clsDef; |
| 202 | } |
| 203 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 204 | return getDefaultDefinition(INTERFACE, getSuffixedName(yangName, BUILDER), |
| 205 | null); |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 206 | } |
| 207 | |
| 208 | /** |
| 209 | * Returns builder file class definition. |
| 210 | * |
| 211 | * @param yangName file name |
| 212 | * @return definition |
| 213 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 214 | private static String getBuilderClassDefinition(String yangName, |
| 215 | YangNode curNode) { |
| 216 | String mod = getSpecificModifier(PUBLIC, STATIC); |
| 217 | String bName = getSuffixedName(yangName, BUILDER); |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 218 | if (!(curNode instanceof YangCase)) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 219 | String clsDef = getClassDefinitionForWhenExtended(curNode, yangName, |
| 220 | BUILDER_CLASS_MASK); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 221 | if (clsDef != null) { |
| 222 | return clsDef; |
| 223 | } |
| 224 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 225 | if (curNode instanceof RpcNotificationContainer) { |
| 226 | return getDefaultDefinition(CLASS, bName, mod); |
Shankara-Huawei | a1039e5 | 2016-07-14 16:53:09 +0530 | [diff] [blame] | 227 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 228 | return getDefaultDefinitionWithImpl(CLASS, bName, mod, |
| 229 | getBuilderImplStringClassDef(yangName)); |
Shankara-Huawei | a1039e5 | 2016-07-14 16:53:09 +0530 | [diff] [blame] | 230 | } |
| 231 | |
| 232 | /** |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 233 | * Returns impl file class definition. |
| 234 | * |
| 235 | * @param yangName file name |
| 236 | * @return definition |
| 237 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 238 | private static String getImplClassDefinition(String yangName, |
| 239 | YangNode curNode) { |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 240 | if (!(curNode instanceof YangCase)) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 241 | String clsDef = getClassDefinitionForWhenExtended( |
| 242 | curNode, yangName, DEFAULT_CLASS_MASK); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 243 | if (clsDef != null) { |
| 244 | return clsDef; |
| 245 | } |
| 246 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 247 | if (curNode instanceof RpcNotificationContainer) { |
| 248 | return getDefaultDefinitionWithImpl( |
| 249 | CLASS, getSuffixedName(yangName, OP_PARAM), PUBLIC, yangName); |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 250 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 251 | return getDefaultDefinitionWithImpl(CLASS, getDefaultName(yangName), |
| 252 | PUBLIC, yangName); |
Bharat saraswal | 715d3fc | 2016-05-17 19:59:16 +0530 | [diff] [blame] | 253 | } |
| 254 | |
| 255 | /** |
| 256 | * Returns impl file class definition. |
| 257 | * |
| 258 | * @param yangName file name |
| 259 | * @return definition |
| 260 | */ |
| 261 | private static String getClassDefinition(String yangName) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 262 | return getDefaultDefinition(CLASS, yangName, PUBLIC); |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 263 | } |
| 264 | |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 265 | /** |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 266 | * Returns implementation file identity class definition. |
| 267 | * |
| 268 | * @param yangName file name |
| 269 | * @return identity class definition |
| 270 | */ |
| 271 | private static String getIdentityClassDefinition(String yangName, YangNode curNode) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 272 | String error = getErrorMsg(ERROR_MSG_JAVA_IDENTITY, curNode.getName(), |
| 273 | curNode.getLineNumber(), curNode |
| 274 | .getCharPosition(), curNode |
| 275 | .getFileName()); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 276 | if (!(curNode instanceof YangIdentity)) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 277 | throw new TranslatorException(error); |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 278 | } |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 279 | YangIdentity identity = (YangIdentity) curNode; |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 280 | String mod = getSpecificModifier(PUBLIC, ABSTRACT); |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 281 | if (identity.getBaseNode() != null) { |
| 282 | YangIdentity baseIdentity = identity.getBaseNode().getReferredIdentity(); |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 283 | if (baseIdentity == null) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 284 | throw new TranslatorException(error); |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 285 | } |
| 286 | |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 287 | JavaFileInfoTranslator fileInfo = ((JavaFileInfoContainer) baseIdentity) |
| 288 | .getJavaFileInfo(); |
| 289 | return getDefaultDefinitionWithExtends( |
| 290 | CLASS, yangName, mod, getCapitalCase(fileInfo.getJavaName())); |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 291 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 292 | return getDefaultDefinition(CLASS, yangName, mod); |
Shankara-Huawei | 234cd09 | 2016-07-14 11:35:34 +0530 | [diff] [blame] | 293 | } |
| 294 | |
| 295 | /** |
Gaurav Agrawal | 97a5e1c | 2016-04-18 18:53:11 +0530 | [diff] [blame] | 296 | * Returns type file class definition. |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 297 | * |
| 298 | * @param yangName file name |
| 299 | * @return definition |
| 300 | */ |
Gaurav Agrawal | 97a5e1c | 2016-04-18 18:53:11 +0530 | [diff] [blame] | 301 | private static String getTypeClassDefinition(String yangName) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 302 | return getDefaultDefinition(CLASS, yangName, |
| 303 | getSpecificModifier(PUBLIC, FINAL)); |
Bharat saraswal | 022dae9 | 2016-03-04 20:08:09 +0530 | [diff] [blame] | 304 | } |
Gaurav Agrawal | 02a60de | 2016-04-20 15:49:17 +0530 | [diff] [blame] | 305 | |
| 306 | /** |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 307 | * Returns RPC file interface definition. |
Gaurav Agrawal | 02a60de | 2016-04-20 15:49:17 +0530 | [diff] [blame] | 308 | * |
| 309 | * @param yangName file name |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 310 | * @param curNode current YANG node |
Gaurav Agrawal | 02a60de | 2016-04-20 15:49:17 +0530 | [diff] [blame] | 311 | * @return definition |
| 312 | */ |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 313 | private static String getRpcInterfaceDefinition(String yangName, YangNode curNode) { |
| 314 | JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode) |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 315 | .getTempJavaCodeFragmentFiles().getServiceTempFiles() |
| 316 | .getJavaExtendsListHolder(); |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 317 | if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) { |
| 318 | curNode = curNode.getChild(); |
| 319 | while (curNode != null) { |
Gaurav Agrawal | bfce934 | 2016-06-15 13:58:01 +0530 | [diff] [blame] | 320 | if (curNode instanceof YangNotification) { |
Bharat saraswal | af413b8 | 2016-07-14 15:18:20 +0530 | [diff] [blame] | 321 | return getRpcInterfaceDefinitionWhenItExtends(yangName); |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 322 | } |
| 323 | curNode = curNode.getNextSibling(); |
| 324 | } |
| 325 | } |
janani b | 3e357f6 | 2016-05-19 17:39:50 +0530 | [diff] [blame] | 326 | if (yangName.matches(REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE)) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 327 | return getDefaultDefinition(INTERFACE, yangName, PUBLIC); |
Bharat saraswal | 250a747 | 2016-05-12 13:16:57 +0530 | [diff] [blame] | 328 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 329 | String name = getSuffixedName( |
| 330 | yangName.substring(0, yangName.length() - 7), SERVICE); |
| 331 | return getDefaultDefinitionWithImpl(CLASS, yangName, PUBLIC, name); |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 332 | } |
| 333 | |
| 334 | /* Provides class definition when RPC interface needs to extends any event.*/ |
Bharat saraswal | af413b8 | 2016-07-14 15:18:20 +0530 | [diff] [blame] | 335 | private static String getRpcInterfaceDefinitionWhenItExtends(String yangName) { |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 336 | |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 337 | StringBuilder newString = new StringBuilder(yangName); |
| 338 | newString.replace(yangName.lastIndexOf(SERVICE), yangName |
| 339 | .lastIndexOf(SERVICE) + 7, EMPTY_STRING); |
| 340 | return getDefaultDefinitionWithExtends( |
| 341 | INTERFACE, yangName, PUBLIC, getEventExtendsString( |
| 342 | getSuffixedName(newString.toString(), EVENT_STRING), |
| 343 | LISTENER_SERVICE, getSuffixedName(newString.toString(), |
| 344 | EVENT_LISTENER_STRING))); |
Gaurav Agrawal | 02a60de | 2016-04-20 15:49:17 +0530 | [diff] [blame] | 345 | } |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 346 | |
| 347 | /** |
| 348 | * Returns event class definition. |
| 349 | * |
| 350 | * @param javaName file name |
| 351 | * @return definition |
| 352 | */ |
Bharat saraswal | 4aaab4d | 2016-05-17 14:19:38 +0530 | [diff] [blame] | 353 | private static String getEventDefinition(String javaName, String eventName) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 354 | return getDefaultDefinitionWithExtends( |
| 355 | CLASS, javaName, PUBLIC, getEventExtendsString( |
| 356 | getSuffixedName(javaName, EVENT_TYPE), ABSTRACT_EVENT, |
| 357 | eventName)); |
| 358 | |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 359 | } |
| 360 | |
| 361 | /** |
| 362 | * Returns event listener interface definition. |
| 363 | * |
| 364 | * @param javaName file name |
| 365 | * @return definition |
| 366 | */ |
| 367 | private static String getEventListenerDefinition(String javaName) { |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 368 | |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 369 | String name = javaName.substring(0, javaName.length() - 8); |
| 370 | return getDefaultDefinitionWithExtends( |
| 371 | INTERFACE, javaName, PUBLIC, EVENT_LISTENER_STRING + |
| 372 | brackets(OPEN_CLOSE_DIAMOND_WITH_VALUE, name, null)); |
VinodKumarS-Huawei | 6266db3 | 2016-05-10 17:58:57 +0530 | [diff] [blame] | 373 | } |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 374 | |
| 375 | /** |
| 376 | * Returns class definition when class is extending another class. |
| 377 | * |
| 378 | * @param curNode current node |
| 379 | * @param yangName name |
| 380 | * @param genFileTypes gen file type |
| 381 | * @return class definition |
| 382 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 383 | private static String getClassDefinitionForWhenExtended( |
| 384 | YangNode curNode, String yangName, int genFileTypes) { |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 385 | JavaExtendsListHolder holder = ((TempJavaCodeFragmentFilesContainer) curNode) |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 386 | .getTempJavaCodeFragmentFiles().getBeanTempFiles() |
| 387 | .getJavaExtendsListHolder(); |
| 388 | StringBuilder def = new StringBuilder(); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 389 | if (holder.getExtendsList() != null && !holder.getExtendsList().isEmpty()) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 390 | def.append(PUBLIC).append(SPACE); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 391 | switch (genFileTypes) { |
| 392 | case INTERFACE_MASK: |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 393 | def.append(INTERFACE).append(SPACE).append(yangName) |
| 394 | .append(SPACE).append(EXTEND).append(SPACE); |
| 395 | def = new StringBuilder(getDefinitionString(def.toString(), |
| 396 | holder)); |
| 397 | break; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 398 | case BUILDER_INTERFACE_MASK: |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 399 | def.append(INTERFACE) |
| 400 | .append(SPACE).append(yangName).append(BUILDER) |
| 401 | .append(SPACE).append(EXTEND).append(SPACE); |
| 402 | def = new StringBuilder(getDefinitionString( |
| 403 | def.toString(), holder)); |
| 404 | break; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 405 | case BUILDER_CLASS_MASK: |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 406 | def.append(STATIC).append(SPACE).append(CLASS) |
| 407 | .append(SPACE).append(yangName).append(BUILDER) |
| 408 | .append(SPACE).append(EXTEND).append(SPACE); |
| 409 | def = new StringBuilder(getDefinitionString(def.toString(), |
| 410 | holder)); |
| 411 | if (!(curNode instanceof RpcNotificationContainer)) { |
| 412 | def.append(SPACE).append(IMPLEMENTS).append(SPACE) |
| 413 | .append(yangName).append(PERIOD) |
| 414 | .append(yangName).append(BUILDER); |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 415 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 416 | break; |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 417 | case DEFAULT_CLASS_MASK: |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 418 | if (curNode instanceof RpcNotificationContainer) { |
| 419 | def.append(CLASS).append(SPACE).append(yangName) |
| 420 | .append(OP_PARAM).append(SPACE).append(EXTEND) |
| 421 | .append(SPACE); |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 422 | } else { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 423 | def.append(CLASS).append(SPACE).append(DEFAULT_CAPS) |
| 424 | .append(yangName).append(SPACE).append(EXTEND) |
| 425 | .append(SPACE); |
Bharat saraswal | 8beac34 | 2016-08-04 02:00:03 +0530 | [diff] [blame] | 426 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 427 | def = new StringBuilder(getDefinitionString(def.toString(), |
| 428 | holder)); |
| 429 | def.append(SPACE).append(IMPLEMENTS).append(SPACE) |
| 430 | .append(yangName); |
| 431 | break; |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 432 | default: |
| 433 | return null; |
| 434 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 435 | return def.append(SPACE).append(OPEN_CURLY_BRACKET) |
| 436 | .append(NEW_LINE).toString(); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 437 | } |
| 438 | return null; |
| 439 | } |
| 440 | |
| 441 | /** |
| 442 | * Returns updated class definition. |
| 443 | * |
| 444 | * @param def current definition |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 445 | * @param holder extend list holder |
| 446 | * @return updated class definition |
| 447 | */ |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 448 | private static String getDefinitionString(String def, |
| 449 | JavaExtendsListHolder holder) { |
| 450 | StringBuilder builder = new StringBuilder(def); |
| 451 | String str; |
Shankara-Huawei | b756477 | 2016-08-02 18:13:13 +0530 | [diff] [blame] | 452 | for (JavaQualifiedTypeInfoTranslator info : holder.getExtendsList()) { |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 453 | if (!holder.getExtendedClassStore().get(info)) { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 454 | str = info.getClassInfo() + COMMA + SPACE; |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 455 | } else { |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 456 | str = info.getPkgInfo() + PERIOD + info.getClassInfo() + |
| 457 | COMMA + SPACE; |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 458 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 459 | builder.append(str); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 460 | } |
Bharat saraswal | 9fab16b | 2016-09-23 23:27:24 +0530 | [diff] [blame^] | 461 | def = builder.toString(); |
Bharat saraswal | 039f59c | 2016-07-14 21:57:13 +0530 | [diff] [blame] | 462 | return trimAtLast(def, COMMA); |
Bharat saraswal | d14cbe8 | 2016-07-14 13:26:18 +0530 | [diff] [blame] | 463 | } |
Bharat saraswal | 9745996 | 2016-02-20 21:57:16 +0530 | [diff] [blame] | 464 | } |