/* * 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.impl.schema.tree; import com.google.common.base.Optional; import com.google.common.base.Preconditions; import java.util.Collection; 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; import org.opendaylight.yangtools.yang.data.api.schema.tree.DataTreeCandidateNode; import org.opendaylight.yangtools.yang.data.api.schema.tree.ModificationType; final class RecursiveReplaceCandidateNode extends AbstractDataTreeCandidateNode { private final NormalizedNodeContainer> oldData; public RecursiveReplaceCandidateNode(final NormalizedNodeContainer> oldData, final NormalizedNodeContainer> newData) { super(newData); this.oldData = Preconditions.checkNotNull(oldData); } @Override public ModificationType getModificationType() { return ModificationType.WRITE; } @Override public Optional> getDataAfter() { return super.dataOptional(); } @Override public Optional> getDataBefore() { return Optional.>of(oldData); } @Override public DataTreeCandidateNode getModifiedChild(final PathArgument identifier) { return deltaChild(oldData, getData(), identifier); } @Override public Collection getChildNodes() { return deltaChildren(oldData, getData()); } }