blob: 14e71ad52b68ef32b4aa59d6f2395cd01f8c0b6f [file] [log] [blame]
Bharat saraswale2d51d62016-03-23 19:40:35 +05301/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Bharat saraswale2d51d62016-03-23 19:40:35 +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
19import java.io.File;
20import java.io.IOException;
Bharat saraswalb551aae2016-07-14 15:18:20 +053021import java.util.ArrayList;
22import java.util.HashMap;
Bharat saraswale2d51d62016-03-23 19:40:35 +053023import java.util.List;
Bharat saraswalb551aae2016-07-14 15:18:20 +053024import java.util.Map;
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +053025
Bharat saraswalb551aae2016-07-14 15:18:20 +053026import org.onosproject.yangutils.datamodel.YangAtomicPath;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053027import org.onosproject.yangutils.datamodel.YangAugment;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053028import org.onosproject.yangutils.datamodel.YangNode;
Bharat saraswalb551aae2016-07-14 15:18:20 +053029import org.onosproject.yangutils.datamodel.YangNodeIdentifier;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053030import org.onosproject.yangutils.translator.exception.TranslatorException;
Bharat saraswalb551aae2016-07-14 15:18:20 +053031import org.onosproject.yangutils.translator.tojava.JavaCodeGeneratorInfo;
Bharat saraswale2d51d62016-03-23 19:40:35 +053032import org.onosproject.yangutils.translator.tojava.JavaFileInfo;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053033import org.onosproject.yangutils.translator.tojava.JavaFileInfoContainer;
Bharat saraswalb551aae2016-07-14 15:18:20 +053034import org.onosproject.yangutils.translator.tojava.JavaImportData;
35import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053036import org.onosproject.yangutils.translator.tojava.TempJavaBeanFragmentFiles;
Bharat saraswalb551aae2016-07-14 15:18:20 +053037import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFiles;
Bharat saraswalc0e04842016-05-12 13:16:57 +053038import org.onosproject.yangutils.translator.tojava.TempJavaEnumerationFragmentFiles;
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +053039import org.onosproject.yangutils.translator.tojava.TempJavaFragmentFiles;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053040import org.onosproject.yangutils.translator.tojava.TempJavaServiceFragmentFiles;
41import org.onosproject.yangutils.translator.tojava.TempJavaTypeFragmentFiles;
Bharat saraswale2d51d62016-03-23 19:40:35 +053042import org.onosproject.yangutils.utils.io.impl.CopyrightHeader;
43import org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053044import org.onosproject.yangutils.utils.io.impl.YangPluginConfig;
Bharat saraswale2d51d62016-03-23 19:40:35 +053045
46import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_CLASS_MASK;
47import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.BUILDER_INTERFACE_MASK;
Bharat saraswald72411a2016-04-19 01:00:16 +053048import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_ENUM_CLASS;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053049import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_CLASS;
50import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_LISTENER_INTERFACE;
Bharat saraswal33dfa012016-05-17 19:59:16 +053051import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_EVENT_SUBJECT_CLASS;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053052import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_IDENTITY_CLASS;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053053import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_SERVICE_AND_MANAGER;
Bharat saraswale2d51d62016-03-23 19:40:35 +053054import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_TYPEDEF_CLASS;
Gaurav Agrawal338735b2016-04-18 18:53:11 +053055import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_UNION_CLASS;
Bharat saraswale2d51d62016-03-23 19:40:35 +053056import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.IMPL_CLASS_MASK;
57import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.INTERFACE_MASK;
Shankara-Huaweib9999eb2016-07-14 16:53:09 +053058import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.OPERATION_BUILDER_CLASS_MASK;
59import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.OPERATION_CLASS_MASK;
Bharat saraswalc0e04842016-05-12 13:16:57 +053060import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.ATTRIBUTES_MASK;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053061import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.AUGMENTE_CLASS_CONSTRUCTOR_MASK;
Gaurav Agrawal338735b2016-04-18 18:53:11 +053062import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.CONSTRUCTOR_FOR_TYPE_MASK;
Bharat saraswale2d51d62016-03-23 19:40:35 +053063import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.CONSTRUCTOR_IMPL_MASK;
Bharat saraswald72411a2016-04-19 01:00:16 +053064import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.ENUM_IMPL_MASK;
Bharat saraswale2d51d62016-03-23 19:40:35 +053065import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.EQUALS_IMPL_MASK;
Bharat saraswal33dfa012016-05-17 19:59:16 +053066import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.EVENT_ENUM_MASK;
67import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.EVENT_METHOD_MASK;
68import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.EVENT_SUBJECT_ATTRIBUTE_MASK;
69import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.EVENT_SUBJECT_GETTER_MASK;
70import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.EVENT_SUBJECT_SETTER_MASK;
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +053071import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.FROM_STRING_IMPL_MASK;
Bharat saraswale2d51d62016-03-23 19:40:35 +053072import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.GETTER_FOR_CLASS_MASK;
73import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.GETTER_FOR_INTERFACE_MASK;
74import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.HASH_CODE_IMPL_MASK;
Gaurav Agrawal338735b2016-04-18 18:53:11 +053075import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.OF_STRING_IMPL_MASK;
Gaurav Agrawal56527662016-04-20 15:49:17 +053076import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.RPC_IMPL_MASK;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053077import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.RPC_INTERFACE_MASK;
Bharat saraswale2d51d62016-03-23 19:40:35 +053078import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.SETTER_FOR_CLASS_MASK;
79import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.SETTER_FOR_INTERFACE_MASK;
80import static org.onosproject.yangutils.translator.tojava.GeneratedTempFileType.TO_STRING_IMPL_MASK;
Bharat saraswalb551aae2016-07-14 15:18:20 +053081import static org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo.getQualifiedTypeInfoOfCurNode;
82import static org.onosproject.yangutils.translator.tojava.YangJavaModelUtils.getAugmentedNodesPackage;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053083import static org.onosproject.yangutils.translator.tojava.utils.ClassDefinitionGenerator.generateClassDefinition;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053084import static org.onosproject.yangutils.utils.UtilConstants.BUILDER;
Shankara-Huaweidf7b9ca2016-07-14 11:35:34 +053085import static org.onosproject.yangutils.utils.UtilConstants.CLOSE_CURLY_BRACKET;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053086import static org.onosproject.yangutils.utils.UtilConstants.DEFAULT;
Bharat saraswale2d51d62016-03-23 19:40:35 +053087import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053088import static org.onosproject.yangutils.utils.UtilConstants.PACKAGE;
Bharat saraswal33dfa012016-05-17 19:59:16 +053089import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
janani bdd1314f2016-05-19 17:39:50 +053090import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053091import static org.onosproject.yangutils.utils.UtilConstants.SEMI_COLAN;
92import static org.onosproject.yangutils.utils.UtilConstants.SLASH;
93import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswale2d51d62016-03-23 19:40:35 +053094import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.BUILDER_CLASS;
95import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.BUILDER_INTERFACE;
Bharat saraswald72411a2016-04-19 01:00:16 +053096import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.ENUM_CLASS;
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +053097import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.EVENT;
98import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.EVENT_LISTENER;
Bharat saraswal33dfa012016-05-17 19:59:16 +053099import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.EVENT_SUBJECT_CLASS;
Shankara-Huaweib9999eb2016-07-14 16:53:09 +0530100import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.OPERATION_CLASS;
Bharat saraswale2d51d62016-03-23 19:40:35 +0530101import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.IMPL_CLASS;
102import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.INTERFACE;
Gaurav Agrawal56527662016-04-20 15:49:17 +0530103import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.RPC_INTERFACE;
Bharat saraswalc0e04842016-05-12 13:16:57 +0530104import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.RPC_MANAGER;
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530105import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.getJavaDoc;
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530106import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getCamelCase;
107import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getCapitalCase;
108import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getJavaPackageFromPackagePath;
Bharat saraswale2d51d62016-03-23 19:40:35 +0530109import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.insertDataIntoJavaFile;
Bharat saraswal33dfa012016-05-17 19:59:16 +0530110import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.parsePkg;
Bharat saraswale2d51d62016-03-23 19:40:35 +0530111
112/**
Bharat saraswald9822e92016-04-05 15:13:44 +0530113 * Represents utilities for java file generator.
Bharat saraswale2d51d62016-03-23 19:40:35 +0530114 */
115public final class JavaFileGeneratorUtils {
116
117 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530118 * Creates an instance of java file generator util.
Bharat saraswale2d51d62016-03-23 19:40:35 +0530119 */
120 private JavaFileGeneratorUtils() {
121 }
122
123 /**
124 * Returns a file object for generated file.
125 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530126 * @param fileName file name
127 * @param filePath file package path
Bharat saraswale2d51d62016-03-23 19:40:35 +0530128 * @param extension file extension
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530129 * @param handle cached file handle
Bharat saraswale2d51d62016-03-23 19:40:35 +0530130 * @return file object
131 */
132 public static File getFileObject(String filePath, String fileName, String extension, JavaFileInfo handle) {
133
134 return new File(handle.getBaseCodeGenPath() + filePath + SLASH + fileName + extension);
135 }
136
137 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530138 * Returns data stored in temporary files.
Bharat saraswale2d51d62016-03-23 19:40:35 +0530139 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530140 * @param generatedTempFiles temporary file types
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530141 * @param tempJavaFragmentFiles temp java fragment files
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530142 * @param absolutePath absolute path
Bharat saraswale2d51d62016-03-23 19:40:35 +0530143 * @return data stored in temporary files
144 * @throws IOException when failed to get the data from temporary file handle
145 */
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530146 public static String getDataFromTempFileHandle(int generatedTempFiles,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530147 TempJavaFragmentFiles tempJavaFragmentFiles, String absolutePath)
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530148 throws IOException {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530149
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530150 TempJavaTypeFragmentFiles typeFragmentFiles = null;
Bharat saraswale2d51d62016-03-23 19:40:35 +0530151
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530152 if (tempJavaFragmentFiles instanceof TempJavaTypeFragmentFiles) {
153 typeFragmentFiles = (TempJavaTypeFragmentFiles) tempJavaFragmentFiles;
154 }
155
156 TempJavaBeanFragmentFiles beanFragmentFiles = null;
157
158 if (tempJavaFragmentFiles instanceof TempJavaBeanFragmentFiles) {
159 beanFragmentFiles = (TempJavaBeanFragmentFiles) tempJavaFragmentFiles;
160 }
161
162 TempJavaServiceFragmentFiles serviceFragmentFiles = null;
163 if (tempJavaFragmentFiles instanceof TempJavaServiceFragmentFiles) {
164 serviceFragmentFiles = (TempJavaServiceFragmentFiles) tempJavaFragmentFiles;
165 }
Bharat saraswal33dfa012016-05-17 19:59:16 +0530166
Bharat saraswalc0e04842016-05-12 13:16:57 +0530167 if ((generatedTempFiles & ATTRIBUTES_MASK) != 0) {
168 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530169 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getAttributesTempFileHandle(),
170 absolutePath);
Bharat saraswalc0e04842016-05-12 13:16:57 +0530171 } else if ((generatedTempFiles & GETTER_FOR_INTERFACE_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530172 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530173 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getGetterInterfaceTempFileHandle(),
174 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530175 } else if ((generatedTempFiles & SETTER_FOR_INTERFACE_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530176 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530177 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getSetterInterfaceTempFileHandle(),
178 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530179 } else if ((generatedTempFiles & GETTER_FOR_CLASS_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530180 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530181 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getGetterImplTempFileHandle(),
182 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530183 } else if ((generatedTempFiles & SETTER_FOR_CLASS_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530184 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530185 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getSetterImplTempFileHandle(),
186 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530187 } else if ((generatedTempFiles & CONSTRUCTOR_IMPL_MASK) != 0) {
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530188 if (beanFragmentFiles == null) {
189 throw new TranslatorException("Required constructor info is missing.");
190 }
191 return beanFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530192 .getTemporaryDataFromFileHandle(beanFragmentFiles.getConstructorImplTempFileHandle(),
193 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530194 } else if ((generatedTempFiles & HASH_CODE_IMPL_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530195 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530196 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getHashCodeImplTempFileHandle(),
197 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530198 } else if ((generatedTempFiles & EQUALS_IMPL_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530199 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530200 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getEqualsImplTempFileHandle(),
201 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530202 } else if ((generatedTempFiles & TO_STRING_IMPL_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530203 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530204 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getToStringImplTempFileHandle(),
205 absolutePath);
206 } else if ((generatedTempFiles & AUGMENTE_CLASS_CONSTRUCTOR_MASK) != 0) {
207 return tempJavaFragmentFiles
208 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getAugmentConstructorImplTempFileHandle(),
209 absolutePath);
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530210 } else if ((generatedTempFiles & OF_STRING_IMPL_MASK) != 0) {
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530211 if (typeFragmentFiles == null) {
212 throw new TranslatorException("Required of string implementation info is missing.");
213 }
214 return typeFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530215 .getTemporaryDataFromFileHandle(typeFragmentFiles.getOfStringImplTempFileHandle(), absolutePath);
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530216 } else if ((generatedTempFiles & CONSTRUCTOR_FOR_TYPE_MASK) != 0) {
217 if (typeFragmentFiles == null) {
218 throw new TranslatorException("Required constructor implementation info is missing.");
219 }
220 return typeFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530221 .getTemporaryDataFromFileHandle(typeFragmentFiles.getConstructorForTypeTempFileHandle(),
222 absolutePath);
Gaurav Agrawal56527662016-04-20 15:49:17 +0530223 } else if ((generatedTempFiles & FROM_STRING_IMPL_MASK) != 0) {
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530224 return tempJavaFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530225 .getTemporaryDataFromFileHandle(tempJavaFragmentFiles.getFromStringImplTempFileHandle(),
226 absolutePath);
Bharat saraswalc0e04842016-05-12 13:16:57 +0530227 } else if ((generatedTempFiles & ENUM_IMPL_MASK) != 0) {
228 if (!(tempJavaFragmentFiles instanceof TempJavaEnumerationFragmentFiles)) {
229 throw new TranslatorException("Required enum info is missing.");
230 }
231 TempJavaEnumerationFragmentFiles enumFragmentFiles =
232 (TempJavaEnumerationFragmentFiles) tempJavaFragmentFiles;
233 return enumFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530234 .getTemporaryDataFromFileHandle(enumFragmentFiles.getEnumClassTempFileHandle(), absolutePath);
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530235 } else if ((generatedTempFiles & RPC_INTERFACE_MASK) != 0) {
236 if (serviceFragmentFiles == null) {
237 throw new TranslatorException("Required rpc interface info is missing.");
238 }
239 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530240 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getRpcInterfaceTempFileHandle(),
241 absolutePath);
Gaurav Agrawal56527662016-04-20 15:49:17 +0530242 } else if ((generatedTempFiles & RPC_IMPL_MASK) != 0) {
VinodKumarS-Huaweicb3a1f52016-05-10 17:58:57 +0530243 if (serviceFragmentFiles == null) {
244 throw new TranslatorException("Required rpc implementation info is missing.");
245 }
246 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530247 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getRpcImplTempFileHandle(),
248 absolutePath);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530249 } else if ((generatedTempFiles & EVENT_ENUM_MASK) != 0) {
250 if (serviceFragmentFiles == null) {
251 throw new TranslatorException("Required rpc implementation info is missing.");
252 }
253 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530254 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getEventEnumTempFileHandle(),
255 absolutePath);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530256 } else if ((generatedTempFiles & EVENT_METHOD_MASK) != 0) {
257 if (serviceFragmentFiles == null) {
258 throw new TranslatorException("Required rpc implementation info is missing.");
259 }
260 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530261 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getEventMethodTempFileHandle(),
262 absolutePath);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530263 } else if ((generatedTempFiles & EVENT_SUBJECT_GETTER_MASK) != 0) {
264 if (serviceFragmentFiles == null) {
265 throw new TranslatorException("Required rpc implementation info is missing.");
266 }
267 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530268 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getEventSubjectGetterTempFileHandle(),
269 absolutePath);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530270 } else if ((generatedTempFiles & EVENT_SUBJECT_SETTER_MASK) != 0) {
271 if (serviceFragmentFiles == null) {
272 throw new TranslatorException("Required rpc implementation info is missing.");
273 }
274 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530275 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getEventSubjectSetterTempFileHandle(),
276 absolutePath);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530277 } else if ((generatedTempFiles & EVENT_SUBJECT_ATTRIBUTE_MASK) != 0) {
278 if (serviceFragmentFiles == null) {
279 throw new TranslatorException("Required rpc implementation info is missing.");
280 }
281 return serviceFragmentFiles
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530282 .getTemporaryDataFromFileHandle(serviceFragmentFiles.getEventSubjectAttributeTempFileHandle(),
283 absolutePath);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530284 }
285 return null;
286 }
287
288 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530289 * Initiates generation of file based on generated file type.
Bharat saraswale2d51d62016-03-23 19:40:35 +0530290 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530291 * @param file generated file
292 * @param className generated file class name
293 * @param genType generated file type
294 * @param imports imports for the file
295 * @param pkg generated file package
Bharat saraswal33dfa012016-05-17 19:59:16 +0530296 * @param pluginConfig plugin configurations
Bharat saraswale2d51d62016-03-23 19:40:35 +0530297 * @throws IOException when fails to generate a file
298 */
sangyun-han19f8d352016-05-30 19:33:27 +0900299 public static void initiateJavaFileGeneration(File file, String className, int genType, List<String> imports,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530300 String pkg, YangPluginConfig pluginConfig)
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530301 throws IOException {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530302
303 try {
304 file.createNewFile();
sangyun-han19f8d352016-05-30 19:33:27 +0900305 appendContents(file, className, genType, imports, pkg, pluginConfig);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530306 } catch (IOException e) {
307 throw new IOException("Failed to create " + file.getName() + " class file.");
308 }
309 }
310
311 /**
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530312 * Initiates generation of file based on generated file type.
313 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530314 * @param file generated file
315 * @param genType generated file type
316 * @param imports imports for the file
317 * @param curNode current YANG node
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530318 * @param className class name
319 * @throws IOException when fails to generate a file
320 */
sangyun-han19f8d352016-05-30 19:33:27 +0900321 public static void initiateJavaFileGeneration(File file, int genType, List<String> imports,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530322 YangNode curNode, String className)
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530323 throws IOException {
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530324
325 try {
326 file.createNewFile();
sangyun-han19f8d352016-05-30 19:33:27 +0900327 appendContents(file, genType, imports, curNode, className);
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530328 } catch (IOException e) {
329 throw new IOException("Failed to create " + file.getName() + " class file.");
330 }
331 }
332
333 /**
Bharat saraswale2d51d62016-03-23 19:40:35 +0530334 * Appends all the contents into a generated java file.
335 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530336 * @param file generated file
337 * @param genType generated file type
sangyun-han19f8d352016-05-30 19:33:27 +0900338 * @param importsList list of java imports
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530339 * @param curNode current YANG node
340 * @param className class name
sangyun-han19f8d352016-05-30 19:33:27 +0900341 * @throws IOException
Bharat saraswale2d51d62016-03-23 19:40:35 +0530342 */
sangyun-han19f8d352016-05-30 19:33:27 +0900343 private static void appendContents(File file, int genType, List<String> importsList, YangNode curNode,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530344 String className)
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530345 throws IOException {
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530346
347 JavaFileInfo javaFileInfo = ((JavaFileInfoContainer) curNode).getJavaFileInfo();
348
Bharat saraswal33dfa012016-05-17 19:59:16 +0530349 String name = javaFileInfo.getJavaName();
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530350 String path = javaFileInfo.getBaseCodeGenPath() + javaFileInfo.getPackageFilePath();
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530351
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530352 YangNode augmentedNode = null;
353 if (curNode instanceof YangAugment) {
354 augmentedNode = ((YangAugment) curNode).getAugmentedNode();
355 }
Bharat saraswal33dfa012016-05-17 19:59:16 +0530356 String pkgString = null;
sangyun-han19f8d352016-05-30 19:33:27 +0900357 if (genType == GENERATE_EVENT_CLASS
358 || genType == GENERATE_EVENT_LISTENER_INTERFACE
359 || genType == GENERATE_EVENT_SUBJECT_CLASS) {
janani bdd1314f2016-05-19 17:39:50 +0530360 pkgString = parsePackageString((path + PERIOD + name).toLowerCase(), importsList);
Bharat saraswal33dfa012016-05-17 19:59:16 +0530361 } else {
362 pkgString = parsePackageString(path, importsList);
363 }
sangyun-han19f8d352016-05-30 19:33:27 +0900364 switch (genType) {
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530365 case INTERFACE_MASK:
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530366 if (augmentedNode != null) {
367 appendHeaderContents(file, pkgString, importsList, augmentedNode);
368 } else {
369 appendHeaderContents(file, pkgString, importsList);
370 }
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530371 write(file, genType, INTERFACE, curNode, className);
372 break;
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530373 case IMPL_CLASS_MASK:
374 appendHeaderContents(file, pkgString, importsList);
375 write(file, genType, IMPL_CLASS, curNode, className);
376 break;
Shankara-Huaweib9999eb2016-07-14 16:53:09 +0530377 case OPERATION_CLASS_MASK:
378 appendHeaderContents(file, pkgString, importsList);
379 write(file, genType, OPERATION_CLASS, curNode, className);
380 break;
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530381 case BUILDER_CLASS_MASK:
382 write(file, genType, BUILDER_CLASS, curNode, className);
383 break;
Shankara-Huaweib9999eb2016-07-14 16:53:09 +0530384 case OPERATION_BUILDER_CLASS_MASK:
385 write(file, genType, BUILDER_CLASS, curNode, className);
386 break;
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530387 case BUILDER_INTERFACE_MASK:
388 write(file, genType, BUILDER_INTERFACE, curNode, className);
389 break;
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530390 case GENERATE_SERVICE_AND_MANAGER:
391 appendHeaderContents(file, pkgString, importsList);
392 write(file, genType, RPC_INTERFACE, curNode, className);
393 break;
394 case GENERATE_EVENT_CLASS:
395 appendHeaderContents(file, pkgString, importsList);
396 write(file, genType, EVENT, curNode, className);
397 break;
398 case GENERATE_EVENT_LISTENER_INTERFACE:
399 appendHeaderContents(file, pkgString, importsList);
400 write(file, genType, EVENT_LISTENER, curNode, className);
401 break;
402 case GENERATE_EVENT_SUBJECT_CLASS:
403 appendHeaderContents(file, pkgString, importsList);
404 write(file, genType, EVENT_SUBJECT_CLASS, curNode, className);
405 break;
Shankara-Huaweidf7b9ca2016-07-14 11:35:34 +0530406 case GENERATE_IDENTITY_CLASS:
407 appendHeaderContents(file, pkgString, importsList);
408 write(file, genType, EVENT_SUBJECT_CLASS, curNode, className);
409 insertDataIntoJavaFile(file, CLOSE_CURLY_BRACKET);
410 break;
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530411 default:
412 break;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530413 }
414 }
415
416 /**
417 * Appends all the contents into a generated java file.
418 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530419 * @param file generated file
420 * @param fileName generated file name
421 * @param genType generated file type
422 * @param importsList list of java imports
423 * @param pkg generated file package
sangyun-han19f8d352016-05-30 19:33:27 +0900424 * @param pluginConfig plugin configurations
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530425 * @throws IOException when fails to append contents
426 */
sangyun-han19f8d352016-05-30 19:33:27 +0900427 private static void appendContents(File file, String fileName, int genType, List<String> importsList, String pkg,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530428 YangPluginConfig pluginConfig)
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530429 throws IOException {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530430
431 String pkgString = parsePackageString(pkg, importsList);
432
sangyun-han19f8d352016-05-30 19:33:27 +0900433 switch (genType) {
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530434 case GENERATE_TYPEDEF_CLASS:
435 appendHeaderContents(file, pkgString, importsList);
436 write(file, fileName, genType, IMPL_CLASS, pluginConfig);
437 break;
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530438 case GENERATE_UNION_CLASS:
439 appendHeaderContents(file, pkgString, importsList);
440 write(file, fileName, genType, IMPL_CLASS, pluginConfig);
441 break;
442 case GENERATE_ENUM_CLASS:
443 appendHeaderContents(file, pkgString, importsList);
444 write(file, fileName, genType, ENUM_CLASS, pluginConfig);
445 break;
446 default:
447 break;
Bharat saraswale2d51d62016-03-23 19:40:35 +0530448 }
449 }
450
451 /**
452 * Removes base directory path from package and generates package string for file.
453 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530454 * @param javaPkg generated java package
Bharat saraswale2d51d62016-03-23 19:40:35 +0530455 * @param importsList list of imports
456 * @return package string
457 */
458 private static String parsePackageString(String javaPkg, List<String> importsList) {
459
Bharat saraswal33dfa012016-05-17 19:59:16 +0530460 javaPkg = parsePkg(getJavaPackageFromPackagePath(javaPkg));
Bharat saraswale2d51d62016-03-23 19:40:35 +0530461 if (importsList != null) {
462 if (!importsList.isEmpty()) {
463 return PACKAGE + SPACE + javaPkg + SEMI_COLAN + NEW_LINE;
464 } else {
465 return PACKAGE + SPACE + javaPkg + SEMI_COLAN;
466 }
467 } else {
468 return PACKAGE + SPACE + javaPkg + SEMI_COLAN;
469 }
470 }
471
472 /**
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530473 * Appends other contents to interface, impl and typedef classes.
Bharat saraswale2d51d62016-03-23 19:40:35 +0530474 * for example : ONOS copyright, imports and package.
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530475 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530476 * @param file generated file
477 * @param pkg generated package
Bharat saraswale2d51d62016-03-23 19:40:35 +0530478 * @param importsList list of imports
Gaurav Agrawal338735b2016-04-18 18:53:11 +0530479 * @throws IOException when fails to append contents
Bharat saraswale2d51d62016-03-23 19:40:35 +0530480 */
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +0530481 private static void appendHeaderContents(File file, String pkg, List<String> importsList)
482 throws IOException {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530483
484 insertDataIntoJavaFile(file, CopyrightHeader.getCopyrightHeader());
485 insertDataIntoJavaFile(file, pkg);
486
487 /*
488 * TODO: add the file header using
489 * JavaCodeSnippetGen.getFileHeaderComment
490 */
491
492 if (importsList != null) {
493 insertDataIntoJavaFile(file, NEW_LINE);
494 for (String imports : importsList) {
495 insertDataIntoJavaFile(file, imports);
496 }
497 }
498 }
499
500 /**
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530501 * Appends other contents to interface and impl classes when augmented node is not null.
502 * for example : ONOS copyright, imports and package.
503 *
504 * @param file generated file
505 * @param pkg generated package
506 * @param augmentedNode augmented node
507 * @param importsList list of imports
508 * @throws IOException when fails to append contents
509 */
510 private static void appendHeaderContents(File file, String pkg, List<String> importsList, YangNode augmentedNode)
511 throws IOException {
512
513 insertDataIntoJavaFile(file, CopyrightHeader.getCopyrightHeader());
514 insertDataIntoJavaFile(file, pkg);
515
516 /*
517 * TODO: add the file header using
518 * JavaCodeSnippetGen.getFileHeaderComment
519 */
520
521 if (importsList != null) {
522 insertDataIntoJavaFile(file, NEW_LINE);
523 for (String imports : importsList) {
524 if (!imports.contains(getCapitalCase(DEFAULT) + getCapitalCase(getCamelCase(augmentedNode.getName(),
525 null)))
526 && !imports.contains(getCapitalCase(getCamelCase(augmentedNode.getName(), null)) + BUILDER)) {
527 insertDataIntoJavaFile(file, imports);
528 }
529 }
530 }
531 }
532
533 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530534 * Writes data to the specific generated file.
Bharat saraswale2d51d62016-03-23 19:40:35 +0530535 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530536 * @param file generated file
537 * @param genType generated file type
Bharat saraswale2d51d62016-03-23 19:40:35 +0530538 * @param javaDocType java doc type
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530539 * @param curNode current YANG node
540 * @param fileName file name
Bharat saraswale2d51d62016-03-23 19:40:35 +0530541 * @throws IOException when fails to write into a file
542 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530543 private static void write(File file, int genType, JavaDocType javaDocType, YangNode curNode, String fileName)
Bharat saraswale2d51d62016-03-23 19:40:35 +0530544 throws IOException {
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530545
Bharat saraswal33dfa012016-05-17 19:59:16 +0530546 YangPluginConfig pluginConfig = ((JavaFileInfoContainer) curNode).getJavaFileInfo().getPluginConfig();
Bharat saraswalc0e04842016-05-12 13:16:57 +0530547 if ((genType & GENERATE_SERVICE_AND_MANAGER) != 0) {
janani bdd1314f2016-05-19 17:39:50 +0530548 if (!fileName.matches(REGEX_FOR_ANY_STRING_ENDING_WITH_SERVICE)) {
549 insertDataIntoJavaFile(file, getJavaDoc(RPC_MANAGER, fileName, false, pluginConfig));
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530550 insertDataIntoJavaFile(file, JavaCodeSnippetGen.addComponentString());
Bharat saraswalc0e04842016-05-12 13:16:57 +0530551 } else {
Bharat saraswal33dfa012016-05-17 19:59:16 +0530552 insertDataIntoJavaFile(file, getJavaDoc(javaDocType, fileName, false, pluginConfig));
Bharat saraswalc0e04842016-05-12 13:16:57 +0530553 }
554 } else {
Bharat saraswal33dfa012016-05-17 19:59:16 +0530555 insertDataIntoJavaFile(file, getJavaDoc(javaDocType, fileName, false, pluginConfig));
Bharat saraswalc0e04842016-05-12 13:16:57 +0530556 }
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530557 insertDataIntoJavaFile(file, generateClassDefinition(genType, fileName, curNode));
558 }
559
560 /**
561 * Writes data to the specific generated file.
562 *
VinodKumarS-Huawei2ee9e7e2016-06-01 14:30:22 +0530563 * @param file generated file
564 * @param fileName file name
565 * @param genType generated file type
566 * @param javaDocType java doc type
sangyun-han19f8d352016-05-30 19:33:27 +0900567 * @param pluginConfig plugin configurations
sangyun-han38201bb2016-06-01 14:12:07 +0900568 * @throws IOException when fails to write into a file
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530569 */
Bharat saraswal33dfa012016-05-17 19:59:16 +0530570 private static void write(File file, String fileName, int genType, JavaDocType javaDocType,
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530571 YangPluginConfig pluginConfig)
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530572 throws IOException {
Bharat saraswal33dfa012016-05-17 19:59:16 +0530573 insertDataIntoJavaFile(file, getJavaDoc(javaDocType, fileName, false, pluginConfig));
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530574 insertDataIntoJavaFile(file, generateClassDefinition(genType, fileName));
Bharat saraswale2d51d62016-03-23 19:40:35 +0530575 }
576
Bharat saraswalb551aae2016-07-14 15:18:20 +0530577 /**
578 * Returns resolved augments for manager classes.
579 *
580 * @param parent parent node
581 * @return resolved augments for manager classes
582 */
583 public static Map<YangAtomicPath, YangAugment> getResolvedAugmentsForManager(YangNode parent) {
584 Map<YangAtomicPath, YangAugment> resolvedAugmentsForManager = new HashMap<>();
585 YangNodeIdentifier nodeId;
586 List<YangAtomicPath> targets = new ArrayList<>();
587 for (YangAugment augment : getListOfAugments(parent)) {
588 nodeId = augment.getTargetNode().get(0).getNodeIdentifier();
589 if (validateNodeIdentifierInSet(nodeId, targets)) {
590 targets.add(augment.getTargetNode().get(0));
591 resolvedAugmentsForManager.put(augment.getTargetNode().get(0), augment);
592 }
593 }
594 return resolvedAugmentsForManager;
595 }
596
597 /**
598 * Returns set of node identifiers.
599 *
600 * @param parent parent node
601 * @return set of node identifiers
602 */
603 public static List<YangAtomicPath> getSetOfNodeIdentifiers(YangNode parent) {
604
605 List<YangAtomicPath> targets = new ArrayList<>();
606 YangNodeIdentifier nodeId;
607 List<YangAugment> augments = getListOfAugments(parent);
608 for (YangAugment augment : augments) {
609 nodeId = augment.getTargetNode().get(0).getNodeIdentifier();
610
611 if (validateNodeIdentifierInSet(nodeId, targets)) {
612 targets.add(augment.getTargetNode().get(0));
613 }
614 }
615 return targets;
616 }
617
618 /* Returns list of augments.*/
619 private static List<YangAugment> getListOfAugments(YangNode parent) {
620 List<YangAugment> augments = new ArrayList<>();
621 YangNode child = parent.getChild();
622 while (child != null) {
623 if (child instanceof YangAugment) {
624 augments.add((YangAugment) child);
625 }
626 child = child.getNextSibling();
627 }
628 return augments;
629 }
630
631 /*Validates the set for duplicate names of node identifiers.*/
632 private static boolean validateNodeIdentifierInSet(YangNodeIdentifier nodeId, List<YangAtomicPath> targets) {
633 boolean isPresent = true;
634 for (YangAtomicPath target : targets) {
635 if (target.getNodeIdentifier().getName().equals(nodeId.getName())) {
636 if (target.getNodeIdentifier().getPrefix() != null) {
637 isPresent = !target.getNodeIdentifier().getPrefix().equals(nodeId.getPrefix());
638 } else {
639 isPresent = nodeId.getPrefix() != null;
640 }
641 }
642 }
643 return isPresent;
644 }
645
646 /**
647 * Adds resolved augmented node imports to manager class.
648 *
649 * @param parent parent node
650 */
651 public static void addResolvedAugmentedDataNodeImports(YangNode parent) {
652 Map<YangAtomicPath, YangAugment> resolvedAugmentsForManager = getResolvedAugmentsForManager(parent);
653 List<YangAtomicPath> targets = getSetOfNodeIdentifiers(parent);
654 TempJavaCodeFragmentFiles tempJavaCodeFragmentFiles = ((JavaCodeGeneratorInfo) parent)
655 .getTempJavaCodeFragmentFiles();
656 YangNode augmentedNode;
657 JavaQualifiedTypeInfo javaQualifiedTypeInfo;
658 String curNodeName;
659 JavaFileInfo parentInfo = ((JavaFileInfoContainer) parent).getJavaFileInfo();
660 for (YangAtomicPath nodeId : targets) {
661 augmentedNode = resolvedAugmentsForManager.get(nodeId).getResolveNodeInPath().get(nodeId);
662 if (((JavaFileInfoContainer) augmentedNode).getJavaFileInfo().getJavaName() != null) {
663 curNodeName = ((JavaFileInfoContainer) augmentedNode).getJavaFileInfo().getJavaName();
664 } else {
665 curNodeName = getCapitalCase(getCamelCase(augmentedNode.getName(), parentInfo.getPluginConfig()
666 .getConflictResolver()));
667 }
668
669 javaQualifiedTypeInfo = getQualifiedTypeInfoOfAugmentedNode(augmentedNode, getCapitalCase(curNodeName),
670 parentInfo.getPluginConfig());
671 tempJavaCodeFragmentFiles.getServiceTempFiles().getJavaImportData().addImportInfo(javaQualifiedTypeInfo,
672 parentInfo.getJavaName(), parentInfo.getPackage());
673
674 }
675 }
676
677 /**
678 * Returns qualified type info of augmented node.
679 *
680 * @param augmentedNode augmented node
681 * @param curNodeName current node name
682 * @param pluginConfig plugin configurations
683 * @return qualified type info of augmented node
684 */
685 public static JavaQualifiedTypeInfo getQualifiedTypeInfoOfAugmentedNode(YangNode augmentedNode, String curNodeName,
686 YangPluginConfig pluginConfig) {
687 JavaQualifiedTypeInfo javaQualifiedTypeInfo = getQualifiedTypeInfoOfCurNode(augmentedNode,
688 getCapitalCase(curNodeName));
689 if (javaQualifiedTypeInfo.getPkgInfo() == null) {
690 javaQualifiedTypeInfo.setPkgInfo(getAugmentedNodesPackage(augmentedNode,
691 pluginConfig));
692 }
693 return javaQualifiedTypeInfo;
694 }
695
696 /**
697 * Validates if augmented node is imported in parent node.
698 *
699 * @param javaQualifiedTypeInfo qualified type info
700 * @param importData import data
701 * @return true if present in imports
702 */
703 private static boolean validateQualifiedInfoOfAugmentedNode(JavaQualifiedTypeInfo javaQualifiedTypeInfo,
704 JavaImportData importData) {
705 for (JavaQualifiedTypeInfo curImportInfo : importData.getImportSet()) {
706 if (curImportInfo.getClassInfo()
707 .contentEquals(javaQualifiedTypeInfo.getClassInfo())) {
708 return curImportInfo.getPkgInfo()
709 .contentEquals(javaQualifiedTypeInfo.getPkgInfo());
710 }
711 }
712 return true;
713 }
714
715 /**
716 * Return augmented class name for data methods in manager and service.
717 *
718 * @param augmentedNode augmented node
719 * @param parent parent node
720 * @return augmented class name for data methods in manager and service
721 */
722 public static String getAugmentedClassNameForDataMethods(YangNode augmentedNode, YangNode parent) {
723 String curNodeName;
724 JavaQualifiedTypeInfo javaQualifiedTypeInfo;
725 JavaFileInfo parentInfo = ((JavaFileInfoContainer) parent).getJavaFileInfo();
726 YangPluginConfig pluginConfig = parentInfo.getPluginConfig();
727 TempJavaServiceFragmentFiles tempJavaServiceFragmentFiles = ((JavaCodeGeneratorInfo) parent)
728 .getTempJavaCodeFragmentFiles().getServiceTempFiles();
729 if (((JavaFileInfoContainer) augmentedNode).getJavaFileInfo().getJavaName() != null) {
730 curNodeName = ((JavaFileInfoContainer) augmentedNode).getJavaFileInfo().getJavaName();
731 } else {
732 curNodeName = getCapitalCase(getCamelCase(augmentedNode.getName(), pluginConfig
733 .getConflictResolver()));
734 }
735
736 javaQualifiedTypeInfo = getQualifiedTypeInfoOfAugmentedNode(augmentedNode,
737 getCapitalCase(curNodeName),
738 parentInfo.getPluginConfig());
739 if (validateQualifiedInfoOfAugmentedNode(javaQualifiedTypeInfo,
740 tempJavaServiceFragmentFiles.getJavaImportData())) {
741 return javaQualifiedTypeInfo.getClassInfo();
742 } else {
743 return javaQualifiedTypeInfo.getPkgInfo() + PERIOD + javaQualifiedTypeInfo.getClassInfo();
744 }
745 }
746
747 /**
748 * Returns parent node name for data methods in manager and service.
749 *
750 * @param parent parent node
751 * @param pluginConfig plugin configurations
752 * @return parent node name for data methods in manager and service
753 */
754 public static String getParentNodeNameForDataMethods(YangNode parent, YangPluginConfig pluginConfig) {
755 JavaFileInfo parentInfo = ((JavaFileInfoContainer) parent).getJavaFileInfo();
756 if (parentInfo.getJavaName() != null) {
757 return getCapitalCase(parentInfo.getJavaName());
758 }
759 return getCapitalCase(getCamelCase(parent.getName(), pluginConfig
760 .getConflictResolver()));
761
762 }
763
Bharat saraswale2d51d62016-03-23 19:40:35 +0530764}