/* * 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.yangtools.yang.model.util; import static java.util.Objects.requireNonNull; import com.google.common.collect.ImmutableMap; import java.util.Collection; import java.util.Optional; import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.model.api.ActionDefinition; import org.opendaylight.yangtools.yang.model.api.AugmentationSchemaNode; import org.opendaylight.yangtools.yang.model.api.DataNodeContainer; import org.opendaylight.yangtools.yang.model.api.DataSchemaNode; import org.opendaylight.yangtools.yang.model.api.GroupingDefinition; import org.opendaylight.yangtools.yang.model.api.NotificationDefinition; import org.opendaylight.yangtools.yang.model.api.Status; import org.opendaylight.yangtools.yang.model.api.TypeDefinition; import org.opendaylight.yangtools.yang.model.api.UnknownSchemaNode; import org.opendaylight.yangtools.yang.model.api.UsesNode; import org.opendaylight.yangtools.yang.model.api.stmt.AugmentEffectiveStatement; import org.opendaylight.yangtools.yang.xpath.api.YangXPathExpression.QualifiedBound; /** * Proxy for AugmentationSchema. Child node schemas are replaced with actual schemas from parent. This is needed to * correctly interpret constructs like this: *
 *   
 *     container foo;
 *
 *     augment /foo {
 *       container bar;
 *     }
 *
 *     augment /foo/bar {
 *       container baz;
 *     }
 *   
 * 
* The {@link AugmentationSchemaNode} returned for {@code augment /foo} contains bare {@code container bar}, e.g. it * does not show {@code augment /foo/bar} as an available augmentation -- this is only visible in {@code foo}'s schema * nodes. * *

* Note this class only handles {@link DataSchemaNode}s, not all {@code schema tree} statements, as it strictly should. */ // FIXME: YANGTOOLS-1403: this functionality should be integrated into EffectiveAugmentStatement/AugmentationSchemaNode public final class EffectiveAugmentationSchema implements AugmentationSchemaNode { private final ImmutableMap children; private final AugmentationSchemaNode delegate; public EffectiveAugmentationSchema(final AugmentationSchemaNode augment, final DataNodeContainer target) { delegate = requireNonNull(augment); final var augmentChildren = augment.getChildNodes(); final var builder = ImmutableMap.builderWithExpectedSize(augmentChildren.size()); for (var augChild : augmentChildren) { // parent may have the corresponding child removed via 'deviate unsupported', i.e. the child is effectively // not present at the target site final var qname = augChild.getQName(); final var targetChild = target.dataChildByName(qname); if (targetChild != null) { builder.put(qname, targetChild); } } children = builder.build(); } @Override public Optional getWhenCondition() { return delegate.getWhenCondition(); } @Override public Optional getDescription() { return delegate.getDescription(); } @Override public Optional getReference() { return delegate.getReference(); } @Override public Status getStatus() { return delegate.getStatus(); } @Override public Collection getUnknownSchemaNodes() { return delegate.getUnknownSchemaNodes(); } @Override public Collection> getTypeDefinitions() { return delegate.getTypeDefinitions(); } @Override public Collection getChildNodes() { return children.values(); } @Override public Collection getGroupings() { return delegate.getGroupings(); } @Override public DataSchemaNode dataChildByName(final QName name) { return children.get(requireNonNull(name)); } @Override public Collection getUses() { return delegate.getUses(); } @Override public Collection getActions() { return delegate.getActions(); } @Override public Optional findAction(final QName qname) { return delegate.findAction(qname); } @Override public Collection getNotifications() { return delegate.getNotifications(); } @Override public Optional findNotification(final QName qname) { return delegate.findNotification(qname); } @Override public AugmentEffectiveStatement asEffectiveStatement() { return delegate.asEffectiveStatement(); } }