2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.yangtools.yang.data.impl;
10 import org.opendaylight.yangtools.yang.common.QName;
11 import org.opendaylight.yangtools.yang.data.api.CompositeNode;
12 import org.opendaylight.yangtools.yang.data.api.ModifyAction;
13 import org.opendaylight.yangtools.yang.data.api.MutableCompositeNode;
14 import org.opendaylight.yangtools.yang.data.api.Node;
15 import org.opendaylight.yangtools.yang.data.api.SimpleNode;
17 import java.io.IOException;
18 import java.io.ObjectInputStream;
19 import java.io.ObjectOutputStream;
20 import java.io.Serializable;
21 import java.util.ArrayList;
22 import java.util.Collection;
23 import java.util.Collections;
24 import java.util.HashMap;
25 import java.util.List;
30 * @author michal.rehak
33 public class CompositeNodeTOImpl extends AbstractNodeTO<List<Node<?>>> implements CompositeNode, Serializable {
35 private static final long serialVersionUID = 100L;
37 private Map<QName, List<Node<?>>> nodeMap = new HashMap<>();
42 * use null to create top composite node (without parent)
45 public CompositeNodeTOImpl(QName qname, CompositeNode parent, List<Node<?>> value) {
46 super(qname, parent, value);
53 * use null to create top composite node (without parent)
57 public CompositeNodeTOImpl(QName qname, CompositeNode parent, List<Node<?>> value, ModifyAction modifyAction) {
58 super(qname, parent, value, modifyAction);
62 protected void init() {
63 if (getValue() != null) {
64 nodeMap = NodeUtils.buildNodeMap(getValue());
68 protected Map<QName, List<Node<?>>> getNodeMap() {
73 public List<Node<?>> getChildren() {
74 return Collections.unmodifiableList(getValue() == null ? new ArrayList<Node<?>>() : getValue());
78 public SimpleNode<?> getFirstSimpleByName(QName leafQName) {
79 List<SimpleNode<?>> list = getSimpleNodesByName(leafQName);
87 public List<CompositeNode> getCompositesByName(QName children) {
88 List<Node<?>> toFilter = getNodeMap().get(children);
89 if(toFilter == null) {
90 return Collections.emptyList();
92 List<CompositeNode> list = new ArrayList<CompositeNode>();
93 for (Node<?> node : toFilter) {
94 if (node instanceof CompositeNode) {
95 list.add((CompositeNode) node);
102 public List<SimpleNode<?>> getSimpleNodesByName(QName children) {
103 List<Node<?>> toFilter = getNodeMap().get(children);
104 if(toFilter == null) {
105 return Collections.emptyList();
107 List<SimpleNode<?>> list = new ArrayList<SimpleNode<?>>();
109 for (Node<?> node : toFilter) {
110 if (node instanceof SimpleNode<?>) {
111 list.add((SimpleNode<?>) node);
118 public CompositeNode getFirstCompositeByName(QName container) {
119 List<CompositeNode> list = getCompositesByName(container);
120 if (list.isEmpty()) {
128 * @return TODO:: do we need this method?
130 public SimpleNode<?> getFirstLeafByName(QName leaf) {
131 List<SimpleNode<?>> list = getSimpleNodesByName(leaf);
132 if (list.isEmpty()) {
139 public List<CompositeNode> getCompositesByName(String children) {
140 return getCompositesByName(new QName(getNodeType(), children));
144 public List<SimpleNode<?>> getSimpleNodesByName(String children) {
145 return getSimpleNodesByName(new QName(getNodeType(), children));
149 public MutableCompositeNode asMutable() {
150 throw new IllegalAccessError("cast to mutable is not supported - " + getClass().getSimpleName());
154 public String toString() {
155 return super.toString() + ", children.size = " + (getChildren() != null ? getChildren().size() : "n/a");
159 public void clear() {
164 public boolean containsKey(Object key) {
165 return nodeMap.containsKey(key);
169 public boolean containsValue(Object value) {
170 return nodeMap.containsValue(value);
174 public Set<java.util.Map.Entry<QName, List<Node<?>>>> entrySet() {
175 return nodeMap.entrySet();
179 public boolean equals(Object obj) {
180 return super.equals(obj);
185 return nodeMap.size();
189 public boolean isEmpty() {
190 return nodeMap.isEmpty();
194 public List<Node<?>> get(Object key) {
195 return nodeMap.get(key);
199 public List<Node<?>> put(QName key, List<Node<?>> value) {
200 return nodeMap.put(key, value);
204 public List<Node<?>> remove(Object key) {
205 return nodeMap.remove(key);
209 public void putAll(Map<? extends QName, ? extends List<Node<?>>> m) {
214 public Set<QName> keySet() {
215 return nodeMap.keySet();
219 public Collection<List<Node<?>>> values() {
220 return nodeMap.values();
223 // Serialization related
225 private void readObject(ObjectInputStream aStream) throws IOException, ClassNotFoundException {
226 aStream.defaultReadObject();
227 QName qName = (QName)aStream.readObject();
228 CompositeNode parent = (CompositeNode) aStream.readObject();
229 List<Node<?>> value = (List<Node<?>>) aStream.readObject();
230 ModifyAction modifyAction = (ModifyAction) aStream.readObject();
232 init(qName, parent, value, modifyAction);
235 private void writeObject(ObjectOutputStream aStream) throws IOException {
236 aStream.defaultWriteObject();
237 //manually serialize superclass
238 aStream.writeObject(getQName());
239 aStream.writeObject(getParent());
240 aStream.writeObject(getValue());
241 aStream.writeObject(getModificationAction());