blob: a890ec2f5a2ab2975c4202345fe2069f9b44c184 [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;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053019import java.util.ArrayList;
20import java.util.List;
Bharat saraswalcc1cdab2016-04-16 02:28:25 +053021
Vinod Kumar S38046502016-03-23 15:30:27 +053022import org.onosproject.yangutils.datamodel.YangAugment;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053023import org.onosproject.yangutils.datamodel.YangNodeIdentifier;
Bharat saraswal6ef0b762016-04-05 12:45:45 +053024import org.onosproject.yangutils.translator.exception.TranslatorException;
Vinod Kumar S38046502016-03-23 15:30:27 +053025import org.onosproject.yangutils.translator.tojava.JavaCodeGenerator;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053026import org.onosproject.yangutils.translator.tojava.JavaCodeGeneratorInfo;
Vinod Kumar S38046502016-03-23 15:30:27 +053027import org.onosproject.yangutils.translator.tojava.JavaFileInfo;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053028import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
Vinod Kumar S38046502016-03-23 15:30:27 +053029import org.onosproject.yangutils.translator.tojava.TempJavaCodeFragmentFiles;
Gaurav Agrawal8a5af142016-06-15 13:58:01 +053030import org.onosproject.yangutils.utils.io.impl.YangPluginConfig;
Vinod Kumar S38046502016-03-23 15:30:27 +053031
32import static org.onosproject.yangutils.translator.tojava.GeneratedJavaFileType.GENERATE_INTERFACE_WITH_BUILDER;
Bharat saraswalb551aae2016-07-14 15:18:20 +053033import static org.onosproject.yangutils.translator.tojava.YangJavaModelUtils.generateCodeOfAugmentableNode;
34import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getCamelCase;
Bharat saraswalb1170bd2016-07-14 13:26:18 +053035import static org.onosproject.yangutils.utils.io.impl.YangIoUtils.getCapitalCase;
Vinod Kumar S38046502016-03-23 15:30:27 +053036
37/**
Bharat saraswald9822e92016-04-05 15:13:44 +053038 * Represents augment information extended to support java code generation.
Vinod Kumar S38046502016-03-23 15:30:27 +053039 */
Vinod Kumar Se4b9b0c2016-04-30 21:09:15 +053040public class YangJavaAugment
41 extends YangAugment
42 implements JavaCodeGeneratorInfo, JavaCodeGenerator {
Vinod Kumar S38046502016-03-23 15:30:27 +053043
Bharat saraswal96dfef02016-06-16 00:29:12 +053044 private static final long serialVersionUID = 806201632L;
45
Vinod Kumar S38046502016-03-23 15:30:27 +053046 /**
Bharat saraswalb1170bd2016-07-14 13:26:18 +053047 * Prefix to be added to generated java file for augment node.
48 */
49 private static final String AUGMENTED = "Augmented";
50
51 /**
Vinod Kumar S38046502016-03-23 15:30:27 +053052 * Contains the information of the java file being generated.
53 */
54 private JavaFileInfo javaFileInfo;
55
56 /**
Bharat saraswalb1170bd2016-07-14 13:26:18 +053057 * TargetNodes java qualified info.
58 */
59 private List<JavaQualifiedTypeInfo> extendedClassInfo;
60
61 /**
Vinod Kumar S38046502016-03-23 15:30:27 +053062 * File handle to maintain temporary java code fragments as per the code
63 * snippet types.
64 */
Bharat saraswal96dfef02016-06-16 00:29:12 +053065 private transient TempJavaCodeFragmentFiles tempFileHandle;
Vinod Kumar S38046502016-03-23 15:30:27 +053066
67 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053068 * Creates a YANG java augment object.
Vinod Kumar S38046502016-03-23 15:30:27 +053069 */
70 public YangJavaAugment() {
71 super();
72 setJavaFileInfo(new JavaFileInfo());
Bharat saraswalb1170bd2016-07-14 13:26:18 +053073 setExtendedClassInfo(new ArrayList<>());
Vinod Kumar S38046502016-03-23 15:30:27 +053074 getJavaFileInfo().setGeneratedFileTypes(GENERATE_INTERFACE_WITH_BUILDER);
75 }
76
77 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053078 * Returns the generated java file information.
Vinod Kumar S38046502016-03-23 15:30:27 +053079 *
80 * @return generated java file information
81 */
82 @Override
83 public JavaFileInfo getJavaFileInfo() {
84
85 if (javaFileInfo == null) {
Bharat saraswal6ef0b762016-04-05 12:45:45 +053086 throw new TranslatorException("Missing java info in java datamodel node");
Vinod Kumar S38046502016-03-23 15:30:27 +053087 }
88 return javaFileInfo;
89 }
90
91 /**
Bharat saraswald9822e92016-04-05 15:13:44 +053092 * Sets the java file info object.
Vinod Kumar S38046502016-03-23 15:30:27 +053093 *
94 * @param javaInfo java file info object
95 */
96 @Override
97 public void setJavaFileInfo(JavaFileInfo javaInfo) {
Vinod Kumar S38046502016-03-23 15:30:27 +053098 javaFileInfo = javaInfo;
99 }
100
101 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530102 * Returns the temporary file handle.
Vinod Kumar S38046502016-03-23 15:30:27 +0530103 *
104 * @return temporary file handle
105 */
106 @Override
107 public TempJavaCodeFragmentFiles getTempJavaCodeFragmentFiles() {
Vinod Kumar S38046502016-03-23 15:30:27 +0530108 return tempFileHandle;
109 }
110
111 /**
Bharat saraswald9822e92016-04-05 15:13:44 +0530112 * Sets temporary file handle.
Vinod Kumar S38046502016-03-23 15:30:27 +0530113 *
114 * @param fileHandle temporary file handle
115 */
116 @Override
117 public void setTempJavaCodeFragmentFiles(TempJavaCodeFragmentFiles fileHandle) {
Vinod Kumar S38046502016-03-23 15:30:27 +0530118 tempFileHandle = fileHandle;
119 }
120
121 /**
122 * Prepare the information for java code generation corresponding to YANG
123 * augment info.
124 *
janani bde4ffab2016-04-15 16:18:30 +0530125 * @param yangPlugin YANG plugin config
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530126 * @throws TranslatorException translator operation fail
Vinod Kumar S38046502016-03-23 15:30:27 +0530127 */
128 @Override
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530129 public void generateCodeEntry(YangPluginConfig yangPlugin) throws TranslatorException {
130 try {
131 generateCodeOfAugmentableNode(this, yangPlugin);
132 } catch (IOException e) {
Bharat saraswal96dfef02016-06-16 00:29:12 +0530133 throw new TranslatorException("Failed to generate code for augmentable node " + getName());
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530134 }
Vinod Kumar S38046502016-03-23 15:30:27 +0530135 }
136
137 /**
Bharat saraswalcc1cdab2016-04-16 02:28:25 +0530138 * Create a java file using the YANG augment info.
139 *
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530140 * @throws TranslatorException when failed to do translator operations
Vinod Kumar S38046502016-03-23 15:30:27 +0530141 */
142 @Override
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530143 public void generateCodeExit() throws TranslatorException {
144 try {
145 getTempJavaCodeFragmentFiles().generateJavaFile(GENERATE_INTERFACE_WITH_BUILDER, this);
146 } catch (IOException e) {
Bharat saraswal96dfef02016-06-16 00:29:12 +0530147 throw new TranslatorException("Failed to generate code for augmentable node " + getName());
Bharat saraswalab4c6ba2016-05-17 14:19:38 +0530148 }
Vinod Kumar S38046502016-03-23 15:30:27 +0530149 }
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530150
151 /**
152 * Returns augment class name.
153 *
154 * @return augment class name
155 */
156 public String getAugmentClassName() {
157 YangNodeIdentifier nodeId = getTargetNode().get(getTargetNode().size() - 1).getNodeIdentifier();
Bharat saraswalb551aae2016-07-14 15:18:20 +0530158 String name = getCapitalCase(getCamelCase(nodeId.getName(), null));
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530159 if (nodeId.getPrefix() != null) {
Bharat saraswalb551aae2016-07-14 15:18:20 +0530160 return AUGMENTED + getCapitalCase(nodeId.getPrefix()) + name;
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530161 } else {
Bharat saraswalb551aae2016-07-14 15:18:20 +0530162 return AUGMENTED + name;
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530163 }
164 }
165
166 /**
167 * Returns extended class info.
168 *
169 * @return extended class info
170 */
171 public List<JavaQualifiedTypeInfo> getExtendedClassInfo() {
172 return extendedClassInfo;
173 }
174
175 /**
176 * Sets extended class info.
177 *
Bharat saraswalb551aae2016-07-14 15:18:20 +0530178 * @param augmentedInfo extended class info
Bharat saraswalb1170bd2016-07-14 13:26:18 +0530179 */
180 private void setExtendedClassInfo(List<JavaQualifiedTypeInfo> augmentedInfo) {
181 extendedClassInfo = augmentedInfo;
182 }
183
184 /**
185 * Adds to extended class info list.
186 *
187 * @param augmentedInfo extended class info
188 */
189 public void addToExtendedClassInfo(JavaQualifiedTypeInfo augmentedInfo) {
190 getExtendedClassInfo().add(augmentedInfo);
191 }
192
Vinod Kumar S38046502016-03-23 15:30:27 +0530193}