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.api.schema.tree;
10 import static java.util.Objects.requireNonNull;
12 import java.util.Collection;
13 import java.util.Optional;
14 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
15 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
16 import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNodeContainer;
18 final class RecursiveReplaceCandidateNode extends AbstractDataTreeCandidateNode {
19 private final NormalizedNodeContainer<?, PathArgument, NormalizedNode<?, ?>> oldData;
21 RecursiveReplaceCandidateNode(final NormalizedNodeContainer<?, PathArgument, NormalizedNode<?, ?>> oldData,
22 final NormalizedNodeContainer<?, PathArgument, NormalizedNode<?, ?>> newData) {
24 this.oldData = requireNonNull(oldData);
28 public ModificationType getModificationType() {
29 return ModificationType.WRITE;
33 public Optional<NormalizedNode<?, ?>> getDataAfter() {
34 return dataOptional();
38 public Optional<NormalizedNode<?, ?>> getDataBefore() {
39 return Optional.of(oldData);
43 public Optional<DataTreeCandidateNode> getModifiedChild(final PathArgument identifier) {
44 return DataTreeCandidateNodes.containerDelta(oldData, data(), identifier);
48 public Collection<DataTreeCandidateNode> getChildNodes() {
49 return DataTreeCandidateNodes.containerDelta(oldData, data());