/* * 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.data.api.schema.tree; import static java.util.Objects.requireNonNull; import java.util.Collection; import java.util.Optional; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNodeContainer; final class RecursiveReplaceCandidateNode extends AbstractDataTreeCandidateNode { private final NormalizedNodeContainer> oldData; RecursiveReplaceCandidateNode(final NormalizedNodeContainer> oldData, final NormalizedNodeContainer> newData) { super(newData); this.oldData = requireNonNull(oldData); } @Override public ModificationType getModificationType() { return ModificationType.WRITE; } @Override public Optional> getDataAfter() { return dataOptional(); } @Override public Optional> getDataBefore() { return Optional.of(oldData); } @Override public Optional getModifiedChild(final PathArgument identifier) { return DataTreeCandidateNodes.containerDelta(oldData, data(), identifier); } @Override public Collection getChildNodes() { return DataTreeCandidateNodes.containerDelta(oldData, data()); } }