blob: 34de136e06b2f91f540b3f248df8242f28dc60da [file] [log] [blame]
Vinod Kumar S38046502016-03-23 15:30:27 +05301/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Vinod Kumar S38046502016-03-23 15:30:27 +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 */
16package org.onosproject.yangutils.translator.tojava.javamodel;
17
18import java.io.IOException;
19
20import org.onosproject.yangutils.datamodel.YangBelongsTo;
21import org.onosproject.yangutils.datamodel.YangSubModule;
Bharat saraswal6ef0b762016-04-05 12:45:45 +053022import org.onosproject.yangutils.translator.exception.TranslatorException;
Vinod Kumar S38046502016-03-23 15:30:27 +053023import org.onosproject.yangutils.translator.tojava.HasJavaFileInfo;
24import org.onosproject.yangutils.translator.tojava.HasJavaImportData;
25import org.onosproject.yangutils.translator.tojava.HasTempJavaCodeFragmentFiles;
26import org.onosproject.yangutils.translator.tojava.JavaCodeGenerator;
27import org.onosproject.yangutils.translator.tojava.JavaFileInfo;
28import org.onosproject.yangutils.translator.tojava.JavaImportData;
29import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFiles;
30
31import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_INTERFACE_WITH_BUILDER;
32import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getCamelCase;
33import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getCaptialCase;
34import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getPackageDirPathFromJavaJPackage;
35import static org.onosproject.yangutils.translator.tojava.utils.JavaIdentifierSyntax.getRootPackage;
36import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getAbsolutePackagePath;
37
38/**
Bharat saraswald9822e92016-04-05 15:13:44 +053039 * Represents Sub module information extended to support java code generation.
Vinod Kumar S38046502016-03-23 15:30:27 +053040 */
41public class YangJavaSubModule extends YangSubModule
42 implements JavaCodeGenerator, HasJavaFileInfo,
43 HasJavaImportData, HasTempJavaCodeFragmentFiles {
44
45 /**
46 * Contains the information of the java file being generated.
47 */
48 private JavaFileInfo javaFileInfo;
49
50 /**
51 * Contains information of the imports to be inserted in the java file
52 * generated.
53 */
54 private JavaImportData javaImportData;
55
56 /**
57 * File handle to maintain temporary java code fragments as per the code
58 * snippet types.
59 */
60 private TempJavaCodeFragmentFiles tempFileHandle;
61
62 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053063 * Creates YANG java sub module object.
Vinod Kumar S38046502016-03-23 15:30:27 +053064 */
65 public YangJavaSubModule() {
66 super();
67 setJavaFileInfo(new JavaFileInfo());
68 setJavaImportData(new JavaImportData());
69 getJavaFileInfo().setGeneratedFileTypes(GENERATE_INTERFACE_WITH_BUILDER);
70 }
71
72 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053073 * Returns the generated java file information.
Vinod Kumar S38046502016-03-23 15:30:27 +053074 *
75 * @return generated java file information
76 */
77 @Override
78 public JavaFileInfo getJavaFileInfo() {
Bharat saraswale2d51d62016-03-23 19:40:35 +053079
Vinod Kumar S38046502016-03-23 15:30:27 +053080 if (javaFileInfo == null) {
Bharat saraswal6ef0b762016-04-05 12:45:45 +053081 throw new TranslatorException("Missing java info in java datamodel node");
Vinod Kumar S38046502016-03-23 15:30:27 +053082 }
83 return javaFileInfo;
84 }
85
86 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053087 * Sets the java file info object.
Vinod Kumar S38046502016-03-23 15:30:27 +053088 *
89 * @param javaInfo java file info object
90 */
91 @Override
92 public void setJavaFileInfo(JavaFileInfo javaInfo) {
93 javaFileInfo = javaInfo;
94 }
95
96 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053097 * Returns the data of java imports to be included in generated file.
Vinod Kumar S38046502016-03-23 15:30:27 +053098 *
99 * @return data of java imports to be included in generated file
100 */
101 @Override
102 public JavaImportData getJavaImportData() {
103 return javaImportData;
104 }
105
106 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530107 * Sets the data of java imports to be included in generated file.
Vinod Kumar S38046502016-03-23 15:30:27 +0530108 *
109 * @param javaImportData data of java imports to be included in generated
110 * file
111 */
112 @Override
113 public void setJavaImportData(JavaImportData javaImportData) {
114 this.javaImportData = javaImportData;
115 }
116
117 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530118 * Returns the temporary file handle.
Vinod Kumar S38046502016-03-23 15:30:27 +0530119 *
120 * @return temporary file handle
121 */
122 @Override
123 public TempJavaCodeFragmentFiles getTempJavaCodeFragmentFiles() {
Vinod Kumar S38046502016-03-23 15:30:27 +0530124 return tempFileHandle;
125 }
126
127 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530128 * Sets temporary file handle.
Vinod Kumar S38046502016-03-23 15:30:27 +0530129 *
130 * @param fileHandle temporary file handle
131 */
132 @Override
133 public void setTempJavaCodeFragmentFiles(TempJavaCodeFragmentFiles fileHandle) {
134 tempFileHandle = fileHandle;
135 }
136
137 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530138 * Returns the name space of the module to which the sub module belongs to.
Vinod Kumar S38046502016-03-23 15:30:27 +0530139 *
140 * @param belongsToInfo Information of the module to which the sub module
141 * belongs
142 * @return the name space string of the module.
143 */
144 private String getNameSpaceFromModule(YangBelongsTo belongsToInfo) {
145 // TODO Auto-generated method stub
146 return "";
147 }
148
149 /**
150 * Prepare the information for java code generation corresponding to YANG
151 * container info.
152 *
153 * @param codeGenDir code generation directory
154 * @throws IOException IO operation fail
155 */
156 @Override
157 public void generateCodeEntry(String codeGenDir) throws IOException {
Bharat saraswale2d51d62016-03-23 19:40:35 +0530158
Vinod Kumar S38046502016-03-23 15:30:27 +0530159 getJavaFileInfo().setJavaName(getCaptialCase(getCamelCase(getName())));
160 getJavaFileInfo().setPackage(getRootPackage(getVersion(),
161 getNameSpaceFromModule(getBelongsTo()),
162 getRevision().getRevDate()));
163 getJavaFileInfo().setPackageFilePath(
164 getPackageDirPathFromJavaJPackage(getJavaFileInfo().getPackage()));
165 getJavaFileInfo().setBaseCodeGenPath(codeGenDir);
166
167 String absloutePath = getAbsolutePackagePath(
168 getJavaFileInfo().getBaseCodeGenPath(),
169 getJavaFileInfo().getPackageFilePath());
170
171 setTempJavaCodeFragmentFiles(new TempJavaCodeFragmentFiles(
172 getJavaFileInfo().getGeneratedFileTypes(), absloutePath,
173 getJavaFileInfo().getJavaName()));
174
175 getTempJavaCodeFragmentFiles().addCurNodeLeavesInfoToTempFiles(this);
176 }
177
178 /**
179 * Create a java file using the YANG grouping info.
180 */
181 @Override
182 public void generateCodeExit() {
183 // TODO Auto-generated method stub
Vinod Kumar S38046502016-03-23 15:30:27 +0530184 }
185}