blob: c9b2765d59a7d08a8852722ec347c0bedc86a06b [file] [log] [blame]
Bharat saraswal870c56f2016-02-20 21:57:16 +05301/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Bharat saraswal870c56f2016-02-20 21:57:16 +05303 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package org.onosproject.yangutils.translator.tojava.utils;
18
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053019import java.io.File;
20import java.io.IOException;
Bharat saraswal870c56f2016-02-20 21:57:16 +053021import java.util.ArrayList;
janani bde4ffab2016-04-15 16:18:30 +053022import java.util.List;
Vinod Kumar S38046502016-03-23 15:30:27 +053023import org.onosproject.yangutils.datamodel.YangNode;
b.janani1fef2732016-03-04 12:29:05 +053024import org.onosproject.yangutils.translator.exception.TranslatorException;
Vinod Kumar S38046502016-03-23 15:30:27 +053025import org.onosproject.yangutils.translator.tojava.JavaFileInfo;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053026import org.onosproject.yangutils.translator.tojava.JavaFileInfoContainer;
27import org.onosproject.yangutils.utils.io.impl.YangIoUtils;
28import org.onosproject.yangutils.utils.io.impl.YangToJavaNamingConflictUtil;
Bharat saraswale2d51d62016-03-23 19:40:35 +053029
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053030import static org.onosproject.yangutils.datamodel.utils.DataModelUtils.getParentNodeInGenCode;
Bharat saraswale2d51d62016-03-23 19:40:35 +053031import static org.onosproject.yangutils.utils.UtilConstants.COLAN;
32import static org.onosproject.yangutils.utils.UtilConstants.DEFAULT_BASE_PKG;
33import static org.onosproject.yangutils.utils.UtilConstants.EMPTY_STRING;
34import static org.onosproject.yangutils.utils.UtilConstants.HYPHEN;
35import static org.onosproject.yangutils.utils.UtilConstants.JAVA_KEY_WORDS;
36import static org.onosproject.yangutils.utils.UtilConstants.PERIOD;
37import static org.onosproject.yangutils.utils.UtilConstants.QUOTES;
38import static org.onosproject.yangutils.utils.UtilConstants.REGEX_FOR_FIRST_DIGIT;
janani bde4ffab2016-04-15 16:18:30 +053039import static org.onosproject.yangutils.utils.UtilConstants.REGEX_WITH_ALL_SPECIAL_CHAR;
Bharat saraswal2f11f652016-03-25 18:19:46 +053040import static org.onosproject.yangutils.utils.UtilConstants.REVISION_PREFIX;
Bharat saraswale2d51d62016-03-23 19:40:35 +053041import static org.onosproject.yangutils.utils.UtilConstants.SLASH;
42import static org.onosproject.yangutils.utils.UtilConstants.UNDER_SCORE;
Bharat saraswal2f11f652016-03-25 18:19:46 +053043import static org.onosproject.yangutils.utils.UtilConstants.VERSION_PREFIX;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053044import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.addPackageInfo;
45import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.createDirectories;
46import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getAbsolutePackagePath;
47import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getJavaPackageFromPackagePath;
48import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getPackageDirPathFromJavaJPackage;
Bharat saraswal870c56f2016-02-20 21:57:16 +053049
50/**
Bharat saraswald9822e92016-04-05 15:13:44 +053051 * Represents an utility Class for translating the name from YANG to java convention.
Bharat saraswal870c56f2016-02-20 21:57:16 +053052 */
53public final class JavaIdentifierSyntax {
54
b.janani1fef2732016-03-04 12:29:05 +053055 private static final int MAX_MONTHS = 12;
56 private static final int MAX_DAYS = 31;
57 private static final int INDEX_ZERO = 0;
58 private static final int INDEX_ONE = 1;
59 private static final int INDEX_TWO = 2;
Bharat saraswal6ef0b762016-04-05 12:45:45 +053060 private static final int VALUE_CHECK = 10;
61 private static final String ZERO = "0";
b.janani1fef2732016-03-04 12:29:05 +053062
Bharat saraswal870c56f2016-02-20 21:57:16 +053063 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053064 * Create instance of java identifier syntax.
Bharat saraswal870c56f2016-02-20 21:57:16 +053065 */
66 private JavaIdentifierSyntax() {
67 }
68
69 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053070 * Returns the root package string.
Bharat saraswal870c56f2016-02-20 21:57:16 +053071 *
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053072 * @param version YANG version
73 * @param nameSpace name space of the module
74 * @param revision revision of the module defined
janani bdd1314f2016-05-19 17:39:50 +053075 * @param conflictResolver object of YANG to java naming conflict util
76 * @return the root package string
Bharat saraswal870c56f2016-02-20 21:57:16 +053077 */
janani bdd1314f2016-05-19 17:39:50 +053078 public static String getRootPackage(byte version, String nameSpace, String revision,
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053079 YangToJavaNamingConflictUtil conflictResolver) {
Bharat saraswal870c56f2016-02-20 21:57:16 +053080
81 String pkg;
Bharat saraswale2d51d62016-03-23 19:40:35 +053082 pkg = DEFAULT_BASE_PKG;
83 pkg = pkg + PERIOD;
Bharat saraswal870c56f2016-02-20 21:57:16 +053084 pkg = pkg + getYangVersion(version);
Bharat saraswale2d51d62016-03-23 19:40:35 +053085 pkg = pkg + PERIOD;
janani bdd1314f2016-05-19 17:39:50 +053086 pkg = pkg + getPkgFromNameSpace(nameSpace, conflictResolver);
Bharat saraswale2d51d62016-03-23 19:40:35 +053087 pkg = pkg + PERIOD;
Bharat saraswal870c56f2016-02-20 21:57:16 +053088 pkg = pkg + getYangRevisionStr(revision);
89
Bharat saraswal4bf8b152016-02-25 02:26:43 +053090 return pkg.toLowerCase();
Bharat saraswal870c56f2016-02-20 21:57:16 +053091 }
92
93 /**
94 * Returns version.
95 *
Vinod Kumar Sc4216002016-03-03 19:55:30 +053096 * @param ver YANG version
Bharat saraswal870c56f2016-02-20 21:57:16 +053097 * @return version
98 */
99 private static String getYangVersion(byte ver) {
Bharat saraswal2f11f652016-03-25 18:19:46 +0530100 return VERSION_PREFIX + ver;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530101 }
102
103 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530104 * Returns package name from name space.
Bharat saraswal870c56f2016-02-20 21:57:16 +0530105 *
Gaurav Agrawal8a5af142016-06-15 13:58:01 +0530106 * @param nameSpace name space of YANG module
janani bdd1314f2016-05-19 17:39:50 +0530107 * @param conflictResolver object of YANG to java naming conflict util
Vinod Kumar Sc4216002016-03-03 19:55:30 +0530108 * @return java package name as per java rules
Bharat saraswal870c56f2016-02-20 21:57:16 +0530109 */
janani bdd1314f2016-05-19 17:39:50 +0530110 private static String getPkgFromNameSpace(String nameSpace, YangToJavaNamingConflictUtil conflictResolver) {
Vinod Kumar S38046502016-03-23 15:30:27 +0530111
Bharat saraswal870c56f2016-02-20 21:57:16 +0530112 ArrayList<String> pkgArr = new ArrayList<String>();
Bharat saraswale2d51d62016-03-23 19:40:35 +0530113 nameSpace = nameSpace.replace(QUOTES, EMPTY_STRING);
janani bde4ffab2016-04-15 16:18:30 +0530114 String properNameSpace = nameSpace.replaceAll(REGEX_WITH_ALL_SPECIAL_CHAR, COLAN);
Bharat saraswale2d51d62016-03-23 19:40:35 +0530115 String[] nameSpaceArr = properNameSpace.split(COLAN);
Bharat saraswal870c56f2016-02-20 21:57:16 +0530116
117 for (String nameSpaceString : nameSpaceArr) {
118 pkgArr.add(nameSpaceString);
119 }
janani bdd1314f2016-05-19 17:39:50 +0530120 return getPkgFrmArr(pkgArr, conflictResolver);
Bharat saraswal870c56f2016-02-20 21:57:16 +0530121 }
122
123 /**
124 * Returns revision string array.
125 *
126 * @param date YANG module revision
127 * @return revision string
b.janani1fef2732016-03-04 12:29:05 +0530128 * @throws TranslatorException when date is invalid.
Bharat saraswal870c56f2016-02-20 21:57:16 +0530129 */
Bharat saraswald9822e92016-04-05 15:13:44 +0530130 private static String getYangRevisionStr(String date) throws TranslatorException {
Vinod Kumar S38046502016-03-23 15:30:27 +0530131
Bharat saraswale2d51d62016-03-23 19:40:35 +0530132 String[] revisionArr = date.split(HYPHEN);
Bharat saraswal870c56f2016-02-20 21:57:16 +0530133
Bharat saraswal2f11f652016-03-25 18:19:46 +0530134 String rev = REVISION_PREFIX;
Bharat saraswal2f00b4b2016-03-04 20:08:09 +0530135 rev = rev + revisionArr[INDEX_ZERO];
b.janani1fef2732016-03-04 12:29:05 +0530136
Vinod Kumar S38046502016-03-23 15:30:27 +0530137 if (Integer.parseInt(revisionArr[INDEX_ONE]) <= MAX_MONTHS
b.janani1fef2732016-03-04 12:29:05 +0530138 && Integer.parseInt(revisionArr[INDEX_TWO]) <= MAX_DAYS) {
139 for (int i = INDEX_ONE; i < revisionArr.length; i++) {
140
141 Integer val = Integer.parseInt(revisionArr[i]);
Bharat saraswal6ef0b762016-04-05 12:45:45 +0530142 if (val < VALUE_CHECK) {
143 rev = rev + ZERO;
b.janani1fef2732016-03-04 12:29:05 +0530144 }
145 rev = rev + val;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530146 }
b.janani1fef2732016-03-04 12:29:05 +0530147
148 return rev;
149 } else {
150 throw new TranslatorException("Date in revision is not proper: " + date);
Bharat saraswal870c56f2016-02-20 21:57:16 +0530151 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530152 }
153
154 /**
155 * Returns the package string.
156 *
Gaurav Agrawal8a5af142016-06-15 13:58:01 +0530157 * @param pkgArr package array
janani bdd1314f2016-05-19 17:39:50 +0530158 * @param conflictResolver object of YANG to java naming conflict util
Bharat saraswal870c56f2016-02-20 21:57:16 +0530159 * @return package string
160 */
janani bdd1314f2016-05-19 17:39:50 +0530161 private static String getPkgFrmArr(ArrayList<String> pkgArr, YangToJavaNamingConflictUtil conflictResolver) {
Bharat saraswal870c56f2016-02-20 21:57:16 +0530162
Bharat saraswale2d51d62016-03-23 19:40:35 +0530163 String pkg = EMPTY_STRING;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530164 int size = pkgArr.size();
165 int i = 0;
166 for (String member : pkgArr) {
janani bdd1314f2016-05-19 17:39:50 +0530167 boolean presenceOfKeyword = JAVA_KEY_WORDS.contains(member.toLowerCase());
Bharat saraswale2d51d62016-03-23 19:40:35 +0530168 if (presenceOfKeyword || member.matches(REGEX_FOR_FIRST_DIGIT)) {
Gaurav Agrawal8a5af142016-06-15 13:58:01 +0530169 String prefix = YangIoUtils.getPrefixForIdentifier(conflictResolver);
janani bdd1314f2016-05-19 17:39:50 +0530170 member = prefix + member;
b.janani1fef2732016-03-04 12:29:05 +0530171 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530172 pkg = pkg + member;
173 if (i != size - 1) {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530174 pkg = pkg + PERIOD;
Bharat saraswal870c56f2016-02-20 21:57:16 +0530175 }
176 i++;
177 }
178 return pkg;
179 }
180
181 /**
Bharat saraswald72411a2016-04-19 01:00:16 +0530182 * Returns enum's java name.
183 *
184 * @param name enum's name
185 * @return enum's java name
186 */
187 public static String getEnumJavaAttribute(String name) {
188
janani bdd1314f2016-05-19 17:39:50 +0530189 name = name.replaceAll(REGEX_WITH_ALL_SPECIAL_CHAR, COLAN);
190 String[] strArray = name.split(COLAN);
Bharat saraswald72411a2016-04-19 01:00:16 +0530191 String output = EMPTY_STRING;
janani bdd1314f2016-05-19 17:39:50 +0530192 if (strArray[0].isEmpty()) {
193 List<String> stringArrangement = new ArrayList<String>();
194 for (int i = 1; i < strArray.length; i++) {
195 stringArrangement.add(strArray[i]);
196 }
197 strArray = stringArrangement.toArray(new String[stringArrangement.size()]);
198 }
Bharat saraswald72411a2016-04-19 01:00:16 +0530199 for (int i = 0; i < strArray.length; i++) {
janani bdd1314f2016-05-19 17:39:50 +0530200 if (i > 0 && i < strArray.length) {
Bharat saraswald72411a2016-04-19 01:00:16 +0530201 output = output + UNDER_SCORE;
202 }
janani bdd1314f2016-05-19 17:39:50 +0530203 output = output + strArray[i];
Bharat saraswald72411a2016-04-19 01:00:16 +0530204 }
205 return output;
206 }
207
208 /**
Gaurav Agrawal8a5af142016-06-15 13:58:01 +0530209 * Creates a package structure with package info java file if not present.
Vinod Kumar S38046502016-03-23 15:30:27 +0530210 *
Gaurav Agrawal8a5af142016-06-15 13:58:01 +0530211 * @param yangNode YANG node for which code is being generated
212 * @throws IOException any IO exception
Vinod Kumar S38046502016-03-23 15:30:27 +0530213 */
Gaurav Agrawal8a5af142016-06-15 13:58:01 +0530214 public static void createPackage(YangNode yangNode) throws IOException {
215 if (!(yangNode instanceof JavaFileInfoContainer)) {
216 throw new TranslatorException("current node must have java file info");
217 }
218 String pkgInfo;
219 JavaFileInfo javaFileInfo = ((JavaFileInfoContainer) yangNode).getJavaFileInfo();
220 String pkg = getAbsolutePackagePath(javaFileInfo.getBaseCodeGenPath(), javaFileInfo.getPackageFilePath());
221 if (!doesPackageExist(pkg)) {
222 try {
223 File pack = createDirectories(pkg);
224 YangNode parent = getParentNodeInGenCode(yangNode);
225 if (parent != null) {
226 pkgInfo = ((JavaFileInfoContainer) parent).getJavaFileInfo().getJavaName();
227 addPackageInfo(pack, pkgInfo, getJavaPackageFromPackagePath(pkg), true,
228 ((JavaFileInfoContainer) parent).getJavaFileInfo().getPluginConfig());
229 } else {
230 pkgInfo = ((JavaFileInfoContainer) yangNode).getJavaFileInfo().getJavaName();
231 addPackageInfo(pack, pkgInfo, getJavaPackageFromPackagePath(pkg), false,
232 ((JavaFileInfoContainer) yangNode).getJavaFileInfo().getPluginConfig());
233 }
234 } catch (IOException e) {
235 throw new IOException("failed to create package-info file");
236 }
237 }
238 }
239
240 /**
241 * Checks if the package directory structure created.
242 *
243 * @param pkg Package to check if it is created
244 * @return existence status of package
245 */
246 public static boolean doesPackageExist(String pkg) {
247 File pkgDir = new File(getPackageDirPathFromJavaJPackage(pkg));
248 File pkgWithFile = new File(pkgDir + SLASH + "package-info.java");
249 return pkgDir.exists() && pkgWithFile.isFile();
Vinod Kumar S38046502016-03-23 15:30:27 +0530250 }
Bharat saraswal870c56f2016-02-20 21:57:16 +0530251}