2 * Copyright (c) 2015 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.util.impl.legacy;
10 import static java.util.Objects.requireNonNull;
12 import java.util.concurrent.ConcurrentHashMap;
13 import java.util.concurrent.ConcurrentMap;
14 import org.eclipse.jdt.annotation.NonNull;
15 import org.eclipse.jdt.annotation.Nullable;
16 import org.opendaylight.yangtools.yang.common.QName;
17 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
18 import org.opendaylight.yangtools.yang.data.util.DataSchemaContextNode;
19 import org.opendaylight.yangtools.yang.model.api.DataNodeContainer;
20 import org.opendaylight.yangtools.yang.model.api.DataSchemaNode;
21 import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
23 abstract class DataContainerContextNode extends AbstractInteriorContextNode {
24 private final ConcurrentMap<PathArgument, AbstractDataSchemaContextNode> byArg = new ConcurrentHashMap<>();
25 private final ConcurrentMap<QName, AbstractDataSchemaContextNode> byQName = new ConcurrentHashMap<>();
26 private final DataNodeContainer container;
28 DataContainerContextNode(final PathArgument pathArgument, final DataNodeContainer container,
29 final DataSchemaNode schema) {
30 super(pathArgument, schema);
31 this.container = requireNonNull(container);
35 public AbstractDataSchemaContextNode getChild(final PathArgument child) {
36 var potential = byArg.get(child);
37 if (potential != null) {
40 potential = fromLocalSchema(child);
41 return register(potential);
45 public AbstractDataSchemaContextNode getChild(final QName child) {
46 AbstractDataSchemaContextNode potential = byQName.get(child);
47 if (potential != null) {
50 potential = fromLocalSchemaAndQName(container, child);
51 return register(potential);
55 protected final DataSchemaContextNode enterChild(final QName child, final SchemaInferenceStack stack) {
56 return pushToStack(getChild(child), stack);
60 protected final DataSchemaContextNode enterChild(final PathArgument child, final SchemaInferenceStack stack) {
61 return pushToStack(getChild(child), stack);
64 private static @Nullable DataSchemaContextNode pushToStack(final @Nullable AbstractDataSchemaContextNode child,
65 final @NonNull SchemaInferenceStack stack) {
67 child.pushToStack(stack);
72 private AbstractDataSchemaContextNode fromLocalSchema(final PathArgument child) {
73 return fromSchemaAndQNameChecked(container, child.getNodeType());
76 protected AbstractDataSchemaContextNode fromLocalSchemaAndQName(final DataNodeContainer schema,
78 return fromSchemaAndQNameChecked(schema, child);
81 private AbstractDataSchemaContextNode register(final AbstractDataSchemaContextNode potential) {
82 if (potential != null) {
83 // FIXME: use putIfAbsent() to make sure we do not perform accidental overrwrites
84 byArg.put(potential.pathArgument(), potential);
85 for (QName qname : potential.qnameIdentifiers()) {
86 byQName.put(qname, potential);