X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-binding-broker%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fmd%2Fsal%2Fbinding%2Fimpl%2FLazySerializedContainerNode.java;h=8185446fcdf9823fd6bf72119e1dfb7d179eb627;hp=9eb4ed76f6d15a44b3584e96c7043bf1ca2dce6b;hb=20a32e6459fd1e27e7669bf1ebc7742b96787b94;hpb=0dcdc14a4ff38b39fed0d07658941a09a4c043fd diff --git a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/LazySerializedContainerNode.java b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/LazySerializedContainerNode.java index 9eb4ed76f6..8185446fcd 100644 --- a/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/LazySerializedContainerNode.java +++ b/opendaylight/md-sal/sal-binding-broker/src/main/java/org/opendaylight/controller/md/sal/binding/impl/LazySerializedContainerNode.java @@ -1,22 +1,26 @@ /* - * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. + * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ + package org.opendaylight.controller.md.sal.binding.impl; -import com.google.common.base.Optional; import java.util.Collection; import java.util.Map; -import org.opendaylight.yangtools.binding.data.codec.impl.BindingNormalizedNodeCodecRegistry; +import java.util.Optional; +import org.opendaylight.mdsal.binding.dom.codec.api.BindingNormalizedNodeSerializer; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifier; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode; import org.opendaylight.yangtools.yang.data.api.schema.DataContainerChild; +import org.opendaylight.yangtools.yang.data.api.schema.LeafNode; +import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; +import org.opendaylight.yangtools.yang.model.api.SchemaPath; /** * @@ -28,24 +32,34 @@ class LazySerializedContainerNode implements ContainerNode { private final NodeIdentifier identifier; private final DataObject bindingData; - private BindingNormalizedNodeCodecRegistry registry; + private BindingNormalizedNodeSerializer registry; private ContainerNode domData; - LazySerializedContainerNode(QName identifier, DataObject binding, - BindingNormalizedNodeCodecRegistry registry) { + private LazySerializedContainerNode(final QName identifier, final DataObject binding, + final BindingNormalizedNodeSerializer registry) { this.identifier = new NodeIdentifier(identifier); this.bindingData = binding; this.registry = registry; this.domData = null; } + static NormalizedNode create(final SchemaPath rpcName, final DataObject data, + final BindingNormalizedNodeSerializer codec) { + return new LazySerializedContainerNode(rpcName.getLastComponent(), data, codec); + } + + static NormalizedNode withContextRef(final SchemaPath rpcName, final DataObject data, + final LeafNode contextRef, final BindingNormalizedNodeSerializer codec) { + return new WithContextRef(rpcName.getLastComponent(), data, contextRef, codec); + } + @Override public Map getAttributes() { return delegate().getAttributes(); } private ContainerNode delegate() { - if(domData == null) { + if (domData == null) { domData = registry.toNormalizedNodeRpcData(bindingData); registry = null; } @@ -53,32 +67,59 @@ class LazySerializedContainerNode implements ContainerNode { } @Override - public QName getNodeType() { - return delegate().getNodeType(); + public final QName getNodeType() { + return identifier.getNodeType(); } @Override - public Collection> getValue() { + public final Collection> getValue() { return delegate().getValue(); } @Override - public NodeIdentifier getIdentifier() { + public final NodeIdentifier getIdentifier() { return identifier; } @Override - public Optional> getChild(PathArgument child) { + public Optional> getChild(final PathArgument child) { return delegate().getChild(child); } @Override - public Object getAttributeValue(QName name) { + public final Object getAttributeValue(final QName name) { return delegate().getAttributeValue(name); } - public DataObject bindingData() { + final DataObject bindingData() { return bindingData; } + /** + * Lazy Serialized Node with pre-cached serialized leaf holding routing information. + * + */ + private static final class WithContextRef extends LazySerializedContainerNode { + + private final LeafNode contextRef; + + protected WithContextRef(final QName identifier, final DataObject binding, final LeafNode contextRef, + final BindingNormalizedNodeSerializer registry) { + super(identifier, binding, registry); + this.contextRef = contextRef; + } + + @Override + public Optional> getChild(final PathArgument child) { + /* + * Use precached value of routing field and do not run full serialization if we are + * accessing it. + */ + if (contextRef.getIdentifier().equals(child)) { + return Optional.>of(contextRef); + } + return super.getChild(child); + } + } + }