X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-rest-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Frestconf%2Fimpl%2FCompositeNodeWrapper.java;h=74a32d452e212682abee966adffad4f062577fcb;hp=e000c7e29e21c0a39904088351940d6862e3f42d;hb=91d7c1ee52322acad08e9f81228ac36b3aa684f5;hpb=da5e7b7312777d4a59e099ed207f61f730092416 diff --git a/opendaylight/md-sal/sal-rest-connector/src/main/java/org/opendaylight/controller/sal/restconf/impl/CompositeNodeWrapper.java b/opendaylight/md-sal/sal-rest-connector/src/main/java/org/opendaylight/controller/sal/restconf/impl/CompositeNodeWrapper.java index e000c7e29e..74a32d452e 100644 --- a/opendaylight/md-sal/sal-rest-connector/src/main/java/org/opendaylight/controller/sal/restconf/impl/CompositeNodeWrapper.java +++ b/opendaylight/md-sal/sal-rest-connector/src/main/java/org/opendaylight/controller/sal/restconf/impl/CompositeNodeWrapper.java @@ -24,16 +24,23 @@ public final class CompositeNodeWrapper implements NodeWrapper, C private String localName; private URI namespace; + private QName name; private List> values = new ArrayList<>(); - + public CompositeNodeWrapper(String localName) { this.localName = Preconditions.checkNotNull(localName); } - + public CompositeNodeWrapper(URI namespace, String localName) { this(localName); this.namespace = namespace; } + + @Override + public void setQname(QName name) { + Preconditions.checkState(compositeNode == null, "Cannot change the object, due to data inconsistencies."); + this.name = name; + } @Override public String getLocalName() { @@ -71,155 +78,162 @@ public final class CompositeNodeWrapper implements NodeWrapper, C Preconditions.checkState(compositeNode == null, "Data can be inconsistent."); return Collections.unmodifiableList(values); } + + @Override + public boolean isChangeAllowed() { + return compositeNode == null ? true : false; + } @Override - public CompositeNode unwrap(CompositeNode parent) { + public CompositeNode unwrap() { if (compositeNode == null) { - Preconditions.checkNotNull(namespace); - compositeNode = NodeFactory.createMutableCompositeNode(new QName(namespace, localName), - parent, new ArrayList>(), ModifyAction.CREATE, null); + if (name == null) { + Preconditions.checkNotNull(namespace); + name = new QName(namespace, localName); + } List> nodeValues = new ArrayList<>(); for (NodeWrapper nodeWrapper : values) { - nodeValues.add(nodeWrapper.unwrap(compositeNode)); + nodeValues.add(nodeWrapper.unwrap()); } - compositeNode.setValue(nodeValues); + compositeNode = NodeFactory.createMutableCompositeNode(name, null, nodeValues, null, null); values = null; namespace = null; localName = null; + name = null; } return compositeNode; } @Override public QName getNodeType() { - return unwrap(null).getNodeType(); + return unwrap().getNodeType(); } @Override public CompositeNode getParent() { - return unwrap(null).getParent(); + return unwrap().getParent(); } @Override public List> getValue() { - return unwrap(null).getValue(); + return unwrap().getValue(); } @Override public ModifyAction getModificationAction() { - return unwrap(null).getModificationAction(); + return unwrap().getModificationAction(); } @Override public List> getChildren() { - return unwrap(null).getChildren(); + return unwrap().getChildren(); } @Override public List getCompositesByName(QName children) { - return unwrap(null).getCompositesByName(children); + return unwrap().getCompositesByName(children); } @Override public List getCompositesByName(String children) { - return unwrap(null).getCompositesByName(children); + return unwrap().getCompositesByName(children); } @Override public List> getSimpleNodesByName(QName children) { - return unwrap(null).getSimpleNodesByName(children); + return unwrap().getSimpleNodesByName(children); } @Override public List> getSimpleNodesByName(String children) { - return unwrap(null).getSimpleNodesByName(children); + return unwrap().getSimpleNodesByName(children); } @Override public CompositeNode getFirstCompositeByName(QName container) { - return unwrap(null).getFirstCompositeByName(container); + return unwrap().getFirstCompositeByName(container); } @Override public SimpleNode getFirstSimpleByName(QName leaf) { - return unwrap(null).getFirstSimpleByName(leaf); + return unwrap().getFirstSimpleByName(leaf); } @Override public MutableCompositeNode asMutable() { - return unwrap(null).asMutable(); + return unwrap().asMutable(); } @Override public QName getKey() { - return unwrap(null).getKey(); + return unwrap().getKey(); } @Override public List> setValue(List> value) { - return unwrap(null).setValue(value); + return unwrap().setValue(value); } @Override public int size() { - return unwrap(null).size(); + return unwrap().size(); } @Override public boolean isEmpty() { - return unwrap(null).isEmpty(); + return unwrap().isEmpty(); } @Override public boolean containsKey(Object key) { - return unwrap(null).containsKey(key); + return unwrap().containsKey(key); } @Override public boolean containsValue(Object value) { - return unwrap(null).containsValue(value); + return unwrap().containsValue(value); } @Override public List> get(Object key) { - return unwrap(null).get(key); + return unwrap().get(key); } @Override public List> put(QName key, List> value) { - return unwrap(null).put(key, value); + return unwrap().put(key, value); } @Override public List> remove(Object key) { - return unwrap(null).remove(key); + return unwrap().remove(key); } @Override public void putAll(Map>> m) { - unwrap(null).putAll(m); + unwrap().putAll(m); } @Override public void clear() { - unwrap(null).clear(); + unwrap().clear(); } @Override public Set keySet() { - return unwrap(null).keySet(); + return unwrap().keySet(); } @Override public Collection>> values() { - return unwrap(null).values(); + return unwrap().values(); } @Override public Set>>> entrySet() { - return unwrap(null).entrySet(); + return unwrap().entrySet(); } }