blob: 3ee83fddde3d6def3601647e42e29caab9d265ac [file] [log] [blame]
Bharat saraswalab4c6ba2016-05-17 14:19:38 +05301/*
2 * Copyright 2016-present Open Networking Laboratory
3 *
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.util.ArrayList;
20import java.util.HashMap;
21import java.util.List;
22import java.util.Map;
23
24import org.onosproject.yangutils.datamodel.YangNode;
25import org.onosproject.yangutils.translator.tojava.JavaFileInfo;
26import org.onosproject.yangutils.translator.tojava.JavaFileInfoContainer;
27import org.onosproject.yangutils.translator.tojava.JavaImportData;
28import org.onosproject.yangutils.translator.tojava.JavaQualifiedTypeInfo;
29
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053030import static org.onosproject.yangutils.translator.tojava.utils.TempJavaCodeFragmentFilesUtils.getTempJavaFragement;
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053031
32/**
33 * Represent the extends list for generated java classes. It holds the class details which needs
34 * to be extended by the generated java code.
35 */
36public class JavaExtendsListHolder {
37
38 /**
39 * Creates an instance of JavaExtendsListHolder.
40 */
41 public JavaExtendsListHolder() {
42 setExtendedClassStore(new HashMap<>());
43 setExtendsList(new ArrayList<>());
44 }
45
46 private Map<JavaQualifiedTypeInfo, Boolean> extendedClassStore;
47 private List<JavaQualifiedTypeInfo> extendsList;
48
49 /**
50 * Returns extends list.
51 *
52 * @return extends list
53 */
54 public Map<JavaQualifiedTypeInfo, Boolean> getExtendedClassStore() {
55 return extendedClassStore;
56 }
57
58 /**
59 * Sets extends list.
60 *
61 * @param extendsList list of classes need to be extended
62 */
63 private void setExtendedClassStore(Map<JavaQualifiedTypeInfo, Boolean> extendedClass) {
64 this.extendedClassStore = extendedClass;
65 }
66
67 /**
68 * Adds to the extends list.
69 *
70 * @param info java file info
71 * @param node YANG node
72 */
73 public void addToExtendsList(JavaQualifiedTypeInfo info, YangNode node) {
74 JavaFileInfo fileInfo = ((JavaFileInfoContainer) node).getJavaFileInfo();
75
76 if (!fileInfo.getPackage().equals(info.getPkgInfo())) {
77 JavaImportData importData = getTempJavaFragement(node).getJavaImportData();
78 importData.addImportInfo(info);
Bharat saraswal33dfa012016-05-17 19:59:16 +053079
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053080 /*true means import should be added*/
81 getExtendedClassStore().put(info, true);
82 }
83 getExtendedClassStore().put(info, false);
84 addToExtendsList(info);
85 }
86
87 /**
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053088 * Returns extends list.
89 *
90 * @return the extendsList
91 */
92 public List<JavaQualifiedTypeInfo> getExtendsList() {
93 return extendsList;
94 }
95
96 /**
97 * Sets extends info list.
98 *
99 * @param classInfoList the extends List to set
100 */
101 private void setExtendsList(List<JavaQualifiedTypeInfo> classInfoList) {
102 this.extendsList = classInfoList;
103 }
104
105 /**
106 * Adds extends info to list.
107 *
108 * @param classInfo class info
109 */
110 private void addToExtendsList(JavaQualifiedTypeInfo classInfo) {
111 getExtendsList().add(classInfo);
112 }
113
114}