blob: 97072cf07ab09d4785adbe9f0b97983dbed1a3b4 [file] [log] [blame]
Gaurav Agrawale3ed0d92016-03-23 19:04:17 +05301/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2016-present Open Networking Laboratory
Gaurav Agrawale3ed0d92016-03-23 19:04:17 +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.datamodel;
18
19import java.util.LinkedList;
20import java.util.List;
Bharat saraswald9822e92016-04-05 15:13:44 +053021
Gaurav Agrawale3ed0d92016-03-23 19:04:17 +053022import org.onosproject.yangutils.datamodel.exceptions.DataModelException;
23import org.onosproject.yangutils.parser.Parsable;
24import org.onosproject.yangutils.utils.YangConstructType;
25
26import static org.onosproject.yangutils.datamodel.utils.DataModelUtils.detectCollidingChildUtil;
27
28/*
29 * Reference RFC 6020.
30 *
31 * The "output" statement, which is optional, is used to define output
32 * parameters to the RPC operation. It does not take an argument. The
33 * substatements to "output" define nodes under the RPC's output node.
34 *
35 * If a leaf in the output tree has a "mandatory" statement with the
36 * value "true", the leaf MUST be present in a NETCONF RPC reply.
37 *
38 * If a leaf in the output tree has a default value, the NETCONF client
39 * MUST use this value in the same cases as described in Section 7.6.1.
40 * In these cases, the client MUST operationally behave as if the leaf
41 * was present in the NETCONF RPC reply with the default value as its
42 * value.
43 *
44 * If a "config" statement is present for any node in the output tree,
45 * the "config" statement is ignored.
46 *
47 * If any node has a "when" statement that would evaluate to false, then
48 * this node MUST NOT be present in the output tree.
49 *
50 * The output substatements
51 *
52 * +--------------+---------+-------------+------------------+
53 * | substatement | section | cardinality |data model mapping|
54 * +--------------+---------+-------------+------------------+
55 * | anyxml | 7.10 | 0..n | -not supported |
56 * | choice | 7.9 | 0..n | -child nodes |
57 * | container | 7.5 | 0..n | -child nodes |
58 * | grouping | 7.11 | 0..n | -child nodes |
59 * | leaf | 7.6 | 0..n | -YangLeaf |
60 * | leaf-list | 7.7 | 0..n | -YangLeafList |
61 * | list | 7.8 | 0..n | -child nodes |
62 * | typedef | 7.3 | 0..n | -child nodes |
63 * | uses | 7.12 | 0..n | -child nodes |
64 * +--------------+---------+-------------+------------------+
65 */
66
67/**
Bharat saraswald9822e92016-04-05 15:13:44 +053068 * Represents data model node to maintain information defined in YANG output.
Gaurav Agrawale3ed0d92016-03-23 19:04:17 +053069 */
Bharat saraswalab4c6ba2016-05-17 14:19:38 +053070public class YangOutput extends YangNode
71 implements YangLeavesHolder, Parsable, CollisionDetector, YangAugmentationHolder {
Gaurav Agrawale3ed0d92016-03-23 19:04:17 +053072
73 /**
74 * Name of the output.
75 */
76 private String name;
77
78 /**
79 * List of leaves contained.
80 */
81 private List<YangLeaf> listOfLeaf;
82
83 /**
84 * List of leaf-lists contained.
85 */
86 private List<YangLeafList> listOfLeafList;
87
88 /**
89 * Create a rpc output node.
90 */
91 public YangOutput() {
92 super(YangNodeType.OUTPUT_NODE);
93 listOfLeaf = new LinkedList<YangLeaf>();
94 listOfLeafList = new LinkedList<YangLeafList>();
95 }
96
97 @Override
98 public void detectCollidingChild(String identifierName, YangConstructType dataType) throws DataModelException {
99 // Detect colliding child.
100 detectCollidingChildUtil(identifierName, dataType, this);
101 }
102
103 @Override
104 public void detectSelfCollision(String identifierName, YangConstructType dataType) throws DataModelException {
105 if (this.getName().equals(identifierName)) {
106 throw new DataModelException("YANG file error: Duplicate identifier detected, same as output \""
107 + this.getName() + "\"");
108 }
109 }
110
111 @Override
112 public YangConstructType getYangConstructType() {
113 return YangConstructType.OUTPUT_DATA;
114 }
115
116 @Override
117 public void validateDataOnEntry() throws DataModelException {
118 //TODO: implement the method.
119 }
120
121 @Override
122 public void validateDataOnExit() throws DataModelException {
123 //TODO: implement the method.
124 }
125
126 @Override
127 public List<YangLeaf> getListOfLeaf() {
128 return listOfLeaf;
129 }
130
131 @Override
132 public void addLeaf(YangLeaf leaf) {
133 getListOfLeaf().add(leaf);
134 }
135
136 @Override
137 public List<YangLeafList> getListOfLeafList() {
138 return listOfLeafList;
139 }
140
141 @Override
142 public void addLeafList(YangLeafList leafList) {
143 getListOfLeafList().add(leafList);
144 }
145
146 @Override
147 public String getName() {
148 return name;
149 }
150
151 @Override
152 public void setName(String name) {
153 this.name = name;
154 }
155}