blob: 6ac05815fdfd5a0919ad7695764e5bb0b4428fed [file] [log] [blame]
Bharat saraswal97459962016-02-20 21:57:16 +05301/*
Brian O'Connor0f7908b2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Bharat saraswal97459962016-02-20 21:57:16 +05303 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package org.onosproject.yangutils.utils.io.impl;
18
Bharat saraswal715d3fc2016-05-17 19:59:16 +053019import java.io.BufferedReader;
Bharat saraswal97459962016-02-20 21:57:16 +053020import java.io.BufferedWriter;
21import java.io.File;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053022import java.io.FileReader;
Bharat saraswal97459962016-02-20 21:57:16 +053023import java.io.FileWriter;
24import java.io.IOException;
Vinod Kumar S9f26ae52016-03-23 15:30:27 +053025import java.util.ArrayList;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053026import java.util.Arrays;
Gaurav Agrawalab7c4bd2016-05-17 18:06:38 +053027import java.util.LinkedList;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053028import java.util.List;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053029import java.util.Stack;
30import java.util.regex.Pattern;
Bharat saraswale304c252016-08-16 20:56:20 +053031
VinodKumarS-Huawei6266db32016-05-10 17:58:57 +053032import org.apache.commons.io.FileUtils;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053033import org.onosproject.yangutils.translator.exception.TranslatorException;
Bharat saraswale50edca2016-08-05 01:58:25 +053034import org.onosproject.yangutils.utils.io.YangPluginConfig;
35import org.onosproject.yangutils.utils.io.YangToJavaNamingConflictUtil;
Bharat saraswal97459962016-02-20 21:57:16 +053036
Gaurav Agrawal8a147522016-08-10 13:43:01 +053037import static org.onosproject.yangutils.utils.UtilConstants.CLOSE_PARENTHESIS;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053038import static org.onosproject.yangutils.utils.UtilConstants.COLAN;
Gaurav Agrawal8a147522016-08-10 13:43:01 +053039import static org.onosproject.yangutils.utils.UtilConstants.EIGHT_SPACE_INDENTATION;
Bharat saraswal84366c52016-03-23 19:40:35 +053040import static org.onosproject.yangutils.utils.UtilConstants.EMPTY_STRING;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053041import static org.onosproject.yangutils.utils.UtilConstants.HASH;
Bharat saraswalc2d3be12016-06-16 00:29:12 +053042import static org.onosproject.yangutils.utils.UtilConstants.HYPHEN;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053043import static org.onosproject.yangutils.utils.UtilConstants.JAVA_KEY_WORDS;
Bharat saraswal84366c52016-03-23 19:40:35 +053044import static org.onosproject.yangutils.utils.UtilConstants.NEW_LINE;
Gaurav Agrawal8a147522016-08-10 13:43:01 +053045import static org.onosproject.yangutils.utils.UtilConstants.ONE;
Bharat saraswale3175d32016-08-31 17:50:11 +053046import static org.onosproject.yangutils.utils.UtilConstants.OPEN_CURLY_BRACKET;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053047import static org.onosproject.yangutils.utils.UtilConstants.OPEN_PARENTHESIS;
Bharat saraswal84366c52016-03-23 19:40:35 +053048import static org.onosproject.yangutils.utils.UtilConstants.ORG;
49import static org.onosproject.yangutils.utils.UtilConstants.PACKAGE;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053050import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053051import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_DIGITS_WITH_SINGLE_LETTER;
52import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_FIRST_DIGIT;
53import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_HYPHEN;
54import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_IDENTIFIER_SPECIAL_CHAR;
55import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_PERIOD;
56import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_SINGLE_LETTER;
57import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_UNDERSCORE;
58import static org.onosproject.yangutils.utils.UtilConstants.REGEX_WITH_ALL_SPECIAL_CHAR;
59import static org.onosproject.yangutils.utils.UtilConstants.REGEX_WITH_DIGITS;
60import static org.onosproject.yangutils.utils.UtilConstants.REGEX_WITH_SINGLE_CAPITAL_CASE;
61import static org.onosproject.yangutils.utils.UtilConstants.REGEX_WITH_SINGLE_CAPITAL_CASE_AND_DIGITS_SMALL_CASES;
62import static org.onosproject.yangutils.utils.UtilConstants.REGEX_WITH_UPPERCASE;
Bharat saraswal84366c52016-03-23 19:40:35 +053063import static org.onosproject.yangutils.utils.UtilConstants.SEMI_COLAN;
64import static org.onosproject.yangutils.utils.UtilConstants.SLASH;
65import static org.onosproject.yangutils.utils.UtilConstants.SPACE;
Bharat saraswal84366c52016-03-23 19:40:35 +053066import static org.onosproject.yangutils.utils.UtilConstants.TWELVE_SPACE_INDENTATION;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053067import static org.onosproject.yangutils.utils.UtilConstants.UNDER_SCORE;
Gaurav Agrawal8a147522016-08-10 13:43:01 +053068import static org.onosproject.yangutils.utils.UtilConstants.UNUSED;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053069import static org.onosproject.yangutils.utils.UtilConstants.YANG_AUTO_PREFIX;
Bharat saraswal8beac342016-08-04 02:00:03 +053070import static org.onosproject.yangutils.utils.io.impl.CopyrightHeader.getCopyrightHeader;
Bharat saraswal84366c52016-03-23 19:40:35 +053071import static org.onosproject.yangutils.utils.io.impl.FileSystemUtil.appendFileContents;
72import static org.onosproject.yangutils.utils.io.impl.FileSystemUtil.updateFileHandle;
Bharat saraswalc2d3be12016-06-16 00:29:12 +053073import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.JavaDocType.PACKAGE_INFO;
Gaurav Agrawalbfce9342016-06-15 13:58:01 +053074import static org.onosproject.yangutils.utils.io.impl.JavaDocGen.getJavaDoc;
Vinod Kumar S9f26ae52016-03-23 15:30:27 +053075
Bharat saraswal97459962016-02-20 21:57:16 +053076/**
Bharat saraswal63f26fb2016-04-05 15:13:44 +053077 * Represents common utility functionalities for code generation.
Bharat saraswal97459962016-02-20 21:57:16 +053078 */
79public final class YangIoUtils {
80
Bharat saraswale3175d32016-08-31 17:50:11 +053081 private static final int LINE_SIZE = 118;
82 private static final int SUB_LINE_SIZE = 116;
Bharat saraswal715d3fc2016-05-17 19:59:16 +053083 private static final int ZERO = 0;
Bharat saraswal97459962016-02-20 21:57:16 +053084
85 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +053086 * Creates an instance of YANG io utils.
Bharat saraswal97459962016-02-20 21:57:16 +053087 */
88 private YangIoUtils() {
89 }
90
91 /**
92 * Creates the directory structure.
93 *
94 * @param path directory path
95 * @return directory structure
Bharat saraswal8beac342016-08-04 02:00:03 +053096 * @throws IOException when fails to do IO operations
Bharat saraswal97459962016-02-20 21:57:16 +053097 */
Bharat saraswal8beac342016-08-04 02:00:03 +053098 public static File createDirectories(String path) throws IOException {
b.janani66b749c2016-02-24 12:23:03 +053099 File generatedDir = new File(path);
Bharat saraswal8beac342016-08-04 02:00:03 +0530100 if (!generatedDir.exists()) {
101 boolean isGenerated = generatedDir.mkdirs();
102 if (!isGenerated) {
103 throw new IOException("failed to generated directory " + path);
104 }
105 }
Bharat saraswal97459962016-02-20 21:57:16 +0530106 return generatedDir;
107 }
108
109 /**
110 * Adds package info file for the created directory.
111 *
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530112 * @param path directory path
113 * @param classInfo class info for the package
114 * @param pack package of the directory
115 * @param isChildNode is it a child node
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530116 * @param pluginConfig plugin configurations
Vinod Kumar S08710982016-03-03 19:55:30 +0530117 * @throws IOException when fails to create package info file
Bharat saraswal97459962016-02-20 21:57:16 +0530118 */
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530119 public static void addPackageInfo(File path, String classInfo, String pack, boolean isChildNode,
Bharat saraswalaf413b82016-07-14 15:18:20 +0530120 YangPluginConfig pluginConfig)
Bharat saraswal250a7472016-05-12 13:16:57 +0530121 throws IOException {
Bharat saraswal97459962016-02-20 21:57:16 +0530122
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530123 pack = parsePkg(pack);
124
Bharat saraswal97459962016-02-20 21:57:16 +0530125 try {
126
Bharat saraswal84366c52016-03-23 19:40:35 +0530127 File packageInfo = new File(path + SLASH + "package-info.java");
Bharat saraswal8beac342016-08-04 02:00:03 +0530128 if (!packageInfo.exists()) {
129 boolean isGenerated = packageInfo.createNewFile();
130 if (!isGenerated) {
131 throw new IOException("failed to generated package-info " + path);
132 }
133 }
Bharat saraswal84366c52016-03-23 19:40:35 +0530134 FileWriter fileWriter = new FileWriter(packageInfo);
135 BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);
136
Bharat saraswal8beac342016-08-04 02:00:03 +0530137 bufferedWriter.write(getCopyrightHeader());
Vidyashree Ramab3670472016-08-06 15:49:56 +0530138 //TODO: get the compiler annotations and pass the info
139 bufferedWriter.write(getJavaDoc(PACKAGE_INFO, classInfo, isChildNode, pluginConfig, null));
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530140 String pkg = PACKAGE + SPACE + pack + SEMI_COLAN;
141 if (pkg.length() > LINE_SIZE) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530142 pkg = whenDelimiterIsPresent(pkg, LINE_SIZE);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530143 }
144 bufferedWriter.write(pkg);
b.janani66b749c2016-02-24 12:23:03 +0530145 bufferedWriter.close();
Bharat saraswal84366c52016-03-23 19:40:35 +0530146 fileWriter.close();
Bharat saraswal97459962016-02-20 21:57:16 +0530147 } catch (IOException e) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530148 throw new IOException("Exception occurred while creating package info file.");
Bharat saraswal97459962016-02-20 21:57:16 +0530149 }
150 }
151
152 /**
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530153 * Parses package and returns updated package.
154 *
155 * @param pack package needs to be updated
156 * @return updated package
157 */
158 public static String parsePkg(String pack) {
159
160 if (pack.contains(ORG)) {
161 String[] strArray = pack.split(ORG);
162 if (strArray.length >= 3) {
163 for (int i = 1; i < strArray.length; i++) {
164 if (i == 1) {
165 pack = ORG + strArray[1];
166 } else {
167 pack = pack + ORG + strArray[i];
168 }
169 }
170 } else {
171 pack = ORG + strArray[1];
172 }
173 }
174
175 return pack;
176 }
177
178 /**
Bharat saraswal97459962016-02-20 21:57:16 +0530179 * Cleans the generated directory if already exist in source folder.
180 *
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530181 * @param dir generated directory in previous build
Bharat saraswal84366c52016-03-23 19:40:35 +0530182 * @throws IOException when failed to delete directory
Bharat saraswal97459962016-02-20 21:57:16 +0530183 */
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530184 public static void deleteDirectory(String dir)
185 throws IOException {
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530186 File generatedDirectory = new File(dir);
Bharat saraswal97459962016-02-20 21:57:16 +0530187 if (generatedDirectory.exists()) {
Bharat saraswal97459962016-02-20 21:57:16 +0530188 try {
VinodKumarS-Huawei6266db32016-05-10 17:58:57 +0530189 FileUtils.deleteDirectory(generatedDirectory);
Bharat saraswal97459962016-02-20 21:57:16 +0530190 } catch (IOException e) {
Bharat saraswal250a7472016-05-12 13:16:57 +0530191 throw new IOException(
192 "Failed to delete the generated files in " + generatedDirectory + " directory");
Bharat saraswal97459962016-02-20 21:57:16 +0530193 }
Bharat saraswal97459962016-02-20 21:57:16 +0530194 }
195 }
196
197 /**
Bharat saraswal250a7472016-05-12 13:16:57 +0530198 * Searches and deletes generated temporary directories.
199 *
200 * @param root root directory
201 * @throws IOException when fails to do IO operations.
202 */
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530203 public static void searchAndDeleteTempDir(String root)
204 throws IOException {
Bharat saraswal250a7472016-05-12 13:16:57 +0530205 List<File> store = new LinkedList<>();
206 Stack<String> stack = new Stack<>();
207 stack.push(root);
208
209 while (!stack.empty()) {
210 root = stack.pop();
211 File file = new File(root);
Bharat saraswal8beac342016-08-04 02:00:03 +0530212 File[] fileList = file.listFiles();
213 if (fileList == null || fileList.length == 0) {
Bharat saraswal250a7472016-05-12 13:16:57 +0530214 continue;
215 }
Bharat saraswal8beac342016-08-04 02:00:03 +0530216 for (File current : fileList) {
Bharat saraswal250a7472016-05-12 13:16:57 +0530217 if (current.isDirectory()) {
218 stack.push(current.toString());
219 if (current.getName().endsWith("-Temp")) {
220 store.add(current);
221 }
222 }
223 }
224 }
225
226 for (File dir : store) {
Bharat saraswal4aaab4d2016-05-17 14:19:38 +0530227 FileUtils.deleteDirectory(dir);
Bharat saraswal250a7472016-05-12 13:16:57 +0530228 }
229 }
230
231 /**
Bharat saraswal022dae92016-03-04 20:08:09 +0530232 * Removes extra char from the string.
233 *
Bharat saraswald14cbe82016-07-14 13:26:18 +0530234 * @param valueString string to be trimmed
Bharat saraswal8beac342016-08-04 02:00:03 +0530235 * @param removalString extra chars
Bharat saraswal022dae92016-03-04 20:08:09 +0530236 * @return new string
237 */
Bharat saraswal8beac342016-08-04 02:00:03 +0530238 public static String trimAtLast(String valueString, String removalString) {
Bharat saraswal022dae92016-03-04 20:08:09 +0530239 StringBuilder stringBuilder = new StringBuilder(valueString);
Bharat saraswal8beac342016-08-04 02:00:03 +0530240 int index = valueString.lastIndexOf(removalString);
Bharat saraswald14cbe82016-07-14 13:26:18 +0530241 if (index != -1) {
242 stringBuilder.deleteCharAt(index);
Bharat saraswal022dae92016-03-04 20:08:09 +0530243 }
Bharat saraswald14cbe82016-07-14 13:26:18 +0530244 return stringBuilder.toString();
Bharat saraswal022dae92016-03-04 20:08:09 +0530245 }
246
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530247 /**
Gaurav Agrawal8a147522016-08-10 13:43:01 +0530248 * Replaces the last occurrence of a string with a given string.
249 *
250 * @param valueString string under operation
251 * @param removalString string to be replaced
252 * @param replacingString string with which replacement is to be done
253 * @return new string
254 */
255 public static String replaceLast(String valueString, String removalString, String replacingString) {
256 StringBuilder stringBuilder = new StringBuilder(valueString);
257 int index = valueString.lastIndexOf(removalString);
258 if (index != -1) {
259 stringBuilder.replace(index, index + 1, replacingString);
260 } else {
261 stringBuilder.append(NEW_LINE + EIGHT_SPACE_INDENTATION + UNUSED + OPEN_PARENTHESIS + ONE +
262 CLOSE_PARENTHESIS + SEMI_COLAN);
263 }
264 return stringBuilder.toString();
265
266 // TODO remove generation of ENUM if there is no leaf node.
267 }
268
269
270 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +0530271 * Returns the directory path of the package in canonical form.
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530272 *
273 * @param baseCodeGenPath base path where the generated files needs to be
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530274 * put
275 * @param pathOfJavaPkg java package of the file being generated
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530276 * @return absolute path of the package in canonical form
277 */
278 public static String getDirectory(String baseCodeGenPath, String pathOfJavaPkg) {
279
280 if (pathOfJavaPkg.charAt(pathOfJavaPkg.length() - 1) == File.separatorChar) {
Bharat saraswal84366c52016-03-23 19:40:35 +0530281 pathOfJavaPkg = trimAtLast(pathOfJavaPkg, SLASH);
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530282 }
Bharat saraswal84366c52016-03-23 19:40:35 +0530283 String[] strArray = pathOfJavaPkg.split(SLASH);
284 if (strArray[0].equals(EMPTY_STRING)) {
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530285 return pathOfJavaPkg;
286 } else {
Bharat saraswal84366c52016-03-23 19:40:35 +0530287 return baseCodeGenPath + SLASH + pathOfJavaPkg;
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530288 }
289 }
290
291 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +0530292 * Returns the absolute path of the package in canonical form.
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530293 *
294 * @param baseCodeGenPath base path where the generated files needs to be
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530295 * put
296 * @param pathOfJavaPkg java package of the file being generated
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530297 * @return absolute path of the package in canonical form
298 */
299 public static String getAbsolutePackagePath(String baseCodeGenPath, String pathOfJavaPkg) {
Vinod Kumar S9f26ae52016-03-23 15:30:27 +0530300 return baseCodeGenPath + pathOfJavaPkg;
301 }
302
303 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +0530304 * Merges the temp java files to main java files.
Bharat saraswal84366c52016-03-23 19:40:35 +0530305 *
306 * @param appendFile temp file
Gaurav Agrawalab7c4bd2016-05-17 18:06:38 +0530307 * @param srcFile main file
Bharat saraswal84366c52016-03-23 19:40:35 +0530308 * @throws IOException when fails to append contents
309 */
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530310 public static void mergeJavaFiles(File appendFile, File srcFile)
311 throws IOException {
Bharat saraswal84366c52016-03-23 19:40:35 +0530312 try {
313 appendFileContents(appendFile, srcFile);
314 } catch (IOException e) {
Bharat saraswale3175d32016-08-31 17:50:11 +0530315 throw new IOException("Failed to merge " + appendFile + " in " + srcFile);
Bharat saraswal84366c52016-03-23 19:40:35 +0530316 }
317 }
318
319 /**
Bharat saraswal63f26fb2016-04-05 15:13:44 +0530320 * Inserts data in the generated file.
Bharat saraswal84366c52016-03-23 19:40:35 +0530321 *
322 * @param file file in which need to be inserted
323 * @param data data which need to be inserted
324 * @throws IOException when fails to insert into file
325 */
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530326 public static void insertDataIntoJavaFile(File file, String data)
327 throws IOException {
Bharat saraswal84366c52016-03-23 19:40:35 +0530328 try {
329 updateFileHandle(file, data, false);
330 } catch (IOException e) {
331 throw new IOException("Failed to insert in " + file + "file");
332 }
333 }
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530334
335 /**
336 * Validates a line size in given file whether it is having more then 120 characters.
337 * If yes it will update and give a new file.
338 *
339 * @param dataFile file in which need to verify all lines.
340 * @return updated file
341 * @throws IOException when fails to do IO operations.
342 */
VinodKumarS-Huaweid81eccb2016-06-01 14:30:22 +0530343 public static File validateLineLength(File dataFile)
344 throws IOException {
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530345 FileReader fileReader = new FileReader(dataFile);
346 BufferedReader bufferReader = new BufferedReader(fileReader);
Bharat saraswal8beac342016-08-04 02:00:03 +0530347 String append;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530348 try {
349 StringBuilder stringBuilder = new StringBuilder();
350 String line = bufferReader.readLine();
351
352 while (line != null) {
353 if (line.length() > LINE_SIZE) {
354 if (line.contains(PERIOD)) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530355 line = whenDelimiterIsPresent(line, LINE_SIZE);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530356 } else if (line.contains(SPACE)) {
357 line = whenSpaceIsPresent(line, LINE_SIZE);
358 }
359 stringBuilder.append(line);
360 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530361 append = line + NEW_LINE;
362 stringBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530363 }
364 line = bufferReader.readLine();
365 }
Bharat saraswal8beac342016-08-04 02:00:03 +0530366 FileWriter writer = new FileWriter(dataFile);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530367 writer.write(stringBuilder.toString());
368 writer.close();
Bharat saraswal8beac342016-08-04 02:00:03 +0530369 return dataFile;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530370 } finally {
371 fileReader.close();
372 bufferReader.close();
373 }
374 }
375
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530376 /* When delimiters are present in the given line. */
Bharat saraswal8beac342016-08-04 02:00:03 +0530377 private static String whenDelimiterIsPresent(String line, int lineSize) {
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530378 StringBuilder stringBuilder = new StringBuilder();
Bharat saraswal8beac342016-08-04 02:00:03 +0530379 String append;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530380 if (line.length() > lineSize) {
381 String[] strArray = line.split(Pattern.quote(PERIOD));
382 stringBuilder = updateString(strArray, stringBuilder, PERIOD, lineSize);
383 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530384 append = line + NEW_LINE;
385 stringBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530386 }
387 String[] strArray = stringBuilder.toString().split(NEW_LINE);
388 StringBuilder tempBuilder = new StringBuilder();
389 for (String str : strArray) {
390 if (str.length() > SUB_LINE_SIZE) {
391 if (line.contains(PERIOD) && !line.contains(PERIOD + HASH + OPEN_PARENTHESIS)) {
392 String[] strArr = str.split(Pattern.quote(PERIOD));
393 tempBuilder = updateString(strArr, tempBuilder, PERIOD, SUB_LINE_SIZE);
394 } else if (str.contains(SPACE)) {
395 tempBuilder.append(whenSpaceIsPresent(str, SUB_LINE_SIZE));
396 }
397 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530398 append = str + NEW_LINE;
399 tempBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530400 }
401 }
402 return tempBuilder.toString();
403
404 }
405
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530406 /* When spaces are present in the given line. */
Bharat saraswal2da23bf2016-08-25 15:28:39 +0530407 private static String whenSpaceIsPresent(String line, int lineSize) {
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530408 StringBuilder stringBuilder = new StringBuilder();
Bharat saraswal8beac342016-08-04 02:00:03 +0530409 String append;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530410 if (line.length() > lineSize) {
411 String[] strArray = line.split(SPACE);
412 stringBuilder = updateString(strArray, stringBuilder, SPACE, lineSize);
413 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530414 append = line + NEW_LINE;
415 stringBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530416 }
Bharat saraswal5cd9e9c2016-05-26 23:48:38 +0530417
418 String[] strArray = stringBuilder.toString().split(NEW_LINE);
419 StringBuilder tempBuilder = new StringBuilder();
420 for (String str : strArray) {
Bharat saraswale304c252016-08-16 20:56:20 +0530421 if (str.length() > LINE_SIZE) {
Bharat saraswal5cd9e9c2016-05-26 23:48:38 +0530422 if (str.contains(SPACE)) {
423 String[] strArr = str.split(SPACE);
424 tempBuilder = updateString(strArr, tempBuilder, SPACE, SUB_LINE_SIZE);
425 }
426 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530427 append = str + NEW_LINE;
428 tempBuilder.append(append);
Bharat saraswal5cd9e9c2016-05-26 23:48:38 +0530429 }
430 }
431 return tempBuilder.toString();
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530432 }
433
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530434 /* Updates the given line with the given size conditions. */
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530435 private static StringBuilder updateString(String[] strArray, StringBuilder stringBuilder, String string,
Bharat saraswalaf413b82016-07-14 15:18:20 +0530436 int lineSize) {
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530437
438 StringBuilder tempBuilder = new StringBuilder();
Bharat saraswal8beac342016-08-04 02:00:03 +0530439 String append;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530440 for (String str : strArray) {
Bharat saraswale3175d32016-08-31 17:50:11 +0530441 if (strArray[strArray.length - 1].contains(OPEN_CURLY_BRACKET)) {
442 if (str.equals(strArray[strArray.length - 2])
443 && !str.equals(strArray[0])
444 && tempBuilder.length() < SUB_LINE_SIZE) {
445 String tempString = stringBuilder.toString();
446 stringBuilder.delete(ZERO, stringBuilder.length());
447 tempString = trimAtLast(tempString, string);
448 stringBuilder.append(tempString);
449 if (string.equals(PERIOD)) {
450 append = NEW_LINE + TWELVE_SPACE_INDENTATION + PERIOD + str + string;
451 } else {
452 append = NEW_LINE + TWELVE_SPACE_INDENTATION + str + string;
453 }
454 stringBuilder.append(append);
455 append = EMPTY_STRING;
456 tempBuilder.delete(ZERO, tempBuilder.length());
457 tempBuilder.append(TWELVE_SPACE_INDENTATION);
458 } else {
459 append = str + string;
460 tempBuilder.append(append);
461 }
462 } else {
463 append = str + string;
464 tempBuilder.append(append);
465 }
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530466 if (tempBuilder.length() > lineSize) {
467 String tempString = stringBuilder.toString();
468 stringBuilder.delete(ZERO, stringBuilder.length());
469 tempString = trimAtLast(tempString, string);
470 stringBuilder.append(tempString);
471 if (string.equals(PERIOD)) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530472 append = NEW_LINE + TWELVE_SPACE_INDENTATION + PERIOD + str + string;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530473 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530474 append = NEW_LINE + TWELVE_SPACE_INDENTATION + str + string;
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530475 }
Bharat saraswale304c252016-08-16 20:56:20 +0530476 stringBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530477 tempBuilder.delete(ZERO, tempBuilder.length());
478 tempBuilder.append(TWELVE_SPACE_INDENTATION);
479 } else {
Bharat saraswal8beac342016-08-04 02:00:03 +0530480 stringBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530481 }
482 }
483 String tempString = stringBuilder.toString();
484 tempString = trimAtLast(tempString, string);
485 stringBuilder.delete(ZERO, stringBuilder.length());
Bharat saraswal8beac342016-08-04 02:00:03 +0530486 append = tempString + NEW_LINE;
487 stringBuilder.append(append);
Bharat saraswal715d3fc2016-05-17 19:59:16 +0530488 return stringBuilder;
489 }
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530490
491 /**
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530492 * Returns the java Package from package path.
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530493 *
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530494 * @param packagePath package path
495 * @return java package
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530496 */
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530497 public static String getJavaPackageFromPackagePath(String packagePath) {
498 return packagePath.replace(SLASH, PERIOD);
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530499 }
500
501 /**
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530502 * Returns the directory path corresponding to java package.
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530503 *
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530504 * @param packagePath package path
505 * @return java package
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530506 */
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530507 public static String getPackageDirPathFromJavaJPackage(String packagePath) {
508 return packagePath.replace(PERIOD, SLASH);
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530509 }
510
511 /**
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530512 * Returns the YANG identifier name as java identifier with first letter
513 * in small.
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530514 *
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530515 * @param yangIdentifier identifier in YANG file.
516 * @return corresponding java identifier
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530517 */
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530518 public static String getSmallCase(String yangIdentifier) {
519 return yangIdentifier.substring(0, 1).toLowerCase() + yangIdentifier.substring(1);
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530520 }
521
522 /**
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530523 * Returns the YANG identifier name as java identifier with first letter
524 * in capital.
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530525 *
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530526 * @param yangIdentifier identifier in YANG file
527 * @return corresponding java identifier
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530528 */
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530529 public static String getCapitalCase(String yangIdentifier) {
530 yangIdentifier = yangIdentifier.substring(0, 1).toUpperCase() + yangIdentifier.substring(1);
531 return restrictConsecutiveCapitalCase(yangIdentifier);
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530532 }
533
534 /**
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530535 * Restricts consecutive capital cased string as a rule in camel case.
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530536 *
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530537 * @param consecCapitalCaseRemover which requires the restriction of consecutive capital case
538 * @return string without consecutive capital case
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530539 */
Bharat saraswal8beac342016-08-04 02:00:03 +0530540 private static String restrictConsecutiveCapitalCase(String consecCapitalCaseRemover) {
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530541
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530542 for (int k = 0; k < consecCapitalCaseRemover.length(); k++) {
543 if (k + 1 < consecCapitalCaseRemover.length()) {
544 if (Character.isUpperCase(consecCapitalCaseRemover.charAt(k))) {
545 if (Character.isUpperCase(consecCapitalCaseRemover.charAt(k + 1))) {
546 consecCapitalCaseRemover = consecCapitalCaseRemover.substring(0, k + 1)
547 + consecCapitalCaseRemover.substring(k + 1, k + 2).toLowerCase()
548 + consecCapitalCaseRemover.substring(k + 2);
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530549 }
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530550 }
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530551 }
552 }
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530553 return consecCapitalCaseRemover;
Bharat saraswalc2d3be12016-06-16 00:29:12 +0530554 }
555
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530556 /**
557 * Adds prefix, if the string begins with digit or is a java key word.
558 *
Bharat saraswalaf413b82016-07-14 15:18:20 +0530559 * @param camelCasePrefix string for adding prefix
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530560 * @param conflictResolver object of YANG to java naming conflict util
561 * @return prefixed camel case string
562 */
Bharat saraswal8beac342016-08-04 02:00:03 +0530563 private static String addPrefix(String camelCasePrefix, YangToJavaNamingConflictUtil conflictResolver) {
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530564
565 String prefix = getPrefixForIdentifier(conflictResolver);
566 if (camelCasePrefix.matches(REGEX_FOR_FIRST_DIGIT)) {
567 camelCasePrefix = prefix + camelCasePrefix;
568 }
569 if (JAVA_KEY_WORDS.contains(camelCasePrefix)) {
570 camelCasePrefix = prefix + camelCasePrefix.substring(0, 1).toUpperCase()
571 + camelCasePrefix.substring(1);
572 }
573 return camelCasePrefix;
574 }
575
576 /**
577 * Applies the rule that a string does not end with a capitalized letter and capitalizes
578 * the letter next to a number in an array.
579 *
Bharat saraswalaf413b82016-07-14 15:18:20 +0530580 * @param stringArray containing strings for camel case separation
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530581 * @param conflictResolver object of YANG to java naming conflict util
582 * @return camel case rule checked string
583 */
Bharat saraswal8beac342016-08-04 02:00:03 +0530584 private static String applyCamelCaseRule(String[] stringArray, YangToJavaNamingConflictUtil conflictResolver) {
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530585
586 String ruleChecker = stringArray[0].toLowerCase();
587 int i;
588 if (ruleChecker.matches(REGEX_FOR_FIRST_DIGIT)) {
589 i = 0;
590 ruleChecker = EMPTY_STRING;
591 } else {
592 i = 1;
593 }
594 for (; i < stringArray.length; i++) {
595 if (i + 1 == stringArray.length) {
596 if (stringArray[i].matches(REGEX_FOR_SINGLE_LETTER)
597 || stringArray[i].matches(REGEX_FOR_DIGITS_WITH_SINGLE_LETTER)) {
598 ruleChecker = ruleChecker + stringArray[i].toLowerCase();
599 break;
600 }
601 }
602 if (stringArray[i].matches(REGEX_FOR_FIRST_DIGIT)) {
603 for (int j = 0; j < stringArray[i].length(); j++) {
604 char letterCheck = stringArray[i].charAt(j);
605 if (Character.isLetter(letterCheck)) {
606 stringArray[i] = stringArray[i].substring(0, j)
607 + stringArray[i].substring(j, j + 1).toUpperCase() + stringArray[i].substring(j + 1);
608 break;
609 }
610 }
611 ruleChecker = ruleChecker + stringArray[i];
612 } else {
613 ruleChecker = ruleChecker + stringArray[i].substring(0, 1).toUpperCase() + stringArray[i].substring(1);
614 }
615 }
616 String ruleCheckerWithPrefix = addPrefix(ruleChecker, conflictResolver);
617 return restrictConsecutiveCapitalCase(ruleCheckerWithPrefix);
618 }
619
620 /**
621 * Resolves the conflict when input has upper case.
622 *
Bharat saraswalaf413b82016-07-14 15:18:20 +0530623 * @param stringArray containing strings for upper case conflict resolver
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530624 * @param conflictResolver object of YANG to java naming conflict util
625 * @return camel cased string
626 */
Bharat saraswal8beac342016-08-04 02:00:03 +0530627 private static String upperCaseConflictResolver(String[] stringArray,
628 YangToJavaNamingConflictUtil conflictResolver) {
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530629
630 for (int l = 0; l < stringArray.length; l++) {
631 String[] upperCaseSplitArray = stringArray[l].split(REGEX_WITH_UPPERCASE);
632 for (int m = 0; m < upperCaseSplitArray.length; m++) {
633 if (upperCaseSplitArray[m].matches(REGEX_WITH_SINGLE_CAPITAL_CASE)) {
634 int check = m;
635 while (check + 1 < upperCaseSplitArray.length) {
636 if (upperCaseSplitArray[check + 1].matches(REGEX_WITH_SINGLE_CAPITAL_CASE)) {
637 upperCaseSplitArray[check + 1] = upperCaseSplitArray[check + 1].toLowerCase();
638 check = check + 1;
639 } else if (upperCaseSplitArray[check + 1]
640 .matches(REGEX_WITH_SINGLE_CAPITAL_CASE_AND_DIGITS_SMALL_CASES)) {
641 upperCaseSplitArray[check + 1] = upperCaseSplitArray[check + 1].toLowerCase();
642 break;
643 } else {
644 break;
645 }
646 }
647 }
648 }
649 StringBuilder strBuilder = new StringBuilder();
650 for (String element : upperCaseSplitArray) {
651 strBuilder.append(element);
652 }
653 stringArray[l] = strBuilder.toString();
654 }
Bharat saraswal8beac342016-08-04 02:00:03 +0530655 List<String> result = new ArrayList<>();
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530656 for (String element : stringArray) {
657 String[] capitalCaseSplitArray = element.split(REGEX_WITH_UPPERCASE);
658 for (String letter : capitalCaseSplitArray) {
659 String[] arrayForAddition = letter.split(REGEX_WITH_DIGITS);
660 List<String> list = Arrays.asList(arrayForAddition);
661 for (String str : list) {
662 if (str != null && !str.isEmpty()) {
663 result.add(str);
664 }
665 }
666 }
667 }
668 stringArray = result.toArray(new String[result.size()]);
669 return applyCamelCaseRule(stringArray, conflictResolver);
670 }
671
672 /**
673 * Returns the YANG identifier name as java identifier.
674 *
Bharat saraswalaf413b82016-07-14 15:18:20 +0530675 * @param yangIdentifier identifier in YANG file
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530676 * @param conflictResolver object of YANG to java naming conflict util
677 * @return corresponding java identifier
678 */
679 public static String getCamelCase(String yangIdentifier, YangToJavaNamingConflictUtil conflictResolver) {
680
681 if (conflictResolver != null) {
682 String replacementForHyphen = conflictResolver.getReplacementForHyphen();
683 String replacementForPeriod = conflictResolver.getReplacementForPeriod();
684 String replacementForUnderscore = conflictResolver.getReplacementForUnderscore();
685 if (replacementForPeriod != null) {
686 yangIdentifier = yangIdentifier.replaceAll(REGEX_FOR_PERIOD,
687 PERIOD + replacementForPeriod.toLowerCase() + PERIOD);
688 }
689 if (replacementForUnderscore != null) {
690 yangIdentifier = yangIdentifier.replaceAll(REGEX_FOR_UNDERSCORE,
691 UNDER_SCORE + replacementForUnderscore.toLowerCase() + UNDER_SCORE);
692 }
693 if (replacementForHyphen != null) {
694 yangIdentifier = yangIdentifier.replaceAll(REGEX_FOR_HYPHEN,
695 HYPHEN + replacementForHyphen.toLowerCase() + HYPHEN);
696 }
697 }
698 yangIdentifier = yangIdentifier.replaceAll(REGEX_FOR_IDENTIFIER_SPECIAL_CHAR, COLAN);
699 String[] strArray = yangIdentifier.split(COLAN);
700 if (strArray[0].isEmpty()) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530701 List<String> stringArrangement = new ArrayList<>();
702 stringArrangement.addAll(Arrays.asList(strArray).subList(1, strArray.length));
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530703 strArray = stringArrangement.toArray(new String[stringArrangement.size()]);
704 }
705 return upperCaseConflictResolver(strArray, conflictResolver);
706 }
707
708 /**
709 * Prefix for adding with identifier and namespace, when it is a java keyword or starting with digits.
710 *
711 * @param conflictResolver object of YANG to java naming conflict util
712 * @return prefix which needs to be added
713 */
714 public static String getPrefixForIdentifier(YangToJavaNamingConflictUtil conflictResolver) {
715
716 String prefixForIdentifier = null;
717 if (conflictResolver != null) {
718 prefixForIdentifier = conflictResolver.getPrefixForIdentifier();
719 }
720 if (prefixForIdentifier != null) {
721 prefixForIdentifier = prefixForIdentifier.replaceAll(REGEX_WITH_ALL_SPECIAL_CHAR, COLAN);
722 String[] strArray = prefixForIdentifier.split(COLAN);
723 try {
724 if (strArray[0].isEmpty()) {
Bharat saraswal8beac342016-08-04 02:00:03 +0530725 List<String> stringArrangement = new ArrayList<>();
726 stringArrangement.addAll(Arrays.asList(strArray).subList(1, strArray.length));
Gaurav Agrawalbfce9342016-06-15 13:58:01 +0530727 strArray = stringArrangement.toArray(new String[stringArrangement.size()]);
728 }
729 prefixForIdentifier = strArray[0];
730 for (int j = 1; j < strArray.length; j++) {
731 prefixForIdentifier = prefixForIdentifier + strArray[j].substring(0, 1).toUpperCase() +
732 strArray[j].substring(1);
733 }
734 } catch (ArrayIndexOutOfBoundsException outOfBoundsException) {
735 throw new TranslatorException("The given prefix in pom.xml is invalid.");
736 }
737 } else {
738 prefixForIdentifier = YANG_AUTO_PREFIX;
739 }
740 return prefixForIdentifier;
741 }
Bharat saraswal97459962016-02-20 21:57:16 +0530742}