2 * Copyright (c) 2014 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.api.schema.tree.spi;
10 import java.util.Optional;
11 import org.eclipse.jdt.annotation.Nullable;
12 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
13 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
14 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNodeContainer;
17 * A TreeNode capable of holding child nodes. The fact that any of the children
18 * changed is tracked by the subtree version.
20 abstract class AbstractContainerNode extends AbstractTreeNode {
21 protected AbstractContainerNode(final NormalizedNode<?, ?> data, final Version version) {
25 @SuppressWarnings("unchecked")
26 protected final NormalizedNodeContainer<?, PathArgument, NormalizedNode<?, ?>> castData() {
27 return (NormalizedNodeContainer<?, PathArgument, NormalizedNode<?, ?>>) getData();
30 protected final @Nullable TreeNode getChildFromData(final PathArgument childId) {
31 // We do not cache the instantiated node as it is dirt cheap
32 return getChildFromData(castData(), childId, getVersion());
35 static TreeNode getChildFromData(final NormalizedNodeContainer<?, PathArgument, NormalizedNode<?, ?>> data,
36 final PathArgument childId, final Version version) {
37 final Optional<NormalizedNode<?, ?>> child = data.getChild(childId);
38 return child.isPresent() ? TreeNodeFactory.createTreeNode(child.get(), version) : null;