/*
* Copyright (c) 2014 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 com.google.common.base.Optional;
import java.util.Collection;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
/**
* A single node within a {@link DataTreeCandidate}. The nodes are organized
* in tree hierarchy, reflecting the modification from which this candidate
* was created. The node itself exposes the before- and after-image of the
* tree restricted to the modified nodes.
*/
public interface DataTreeCandidateNode {
/**
* Get the node identifier.
*
* @return The node identifier.
*/
@Nonnull PathArgument getIdentifier();
/**
* Get an unmodifiable collection of modified child nodes.
*
* @return Unmodifiable collection of modified child nodes.
*/
@Nonnull Collection<DataTreeCandidateNode> getChildNodes();
/**
* Returns modified child or null if child was not modified
* / does not exists.
*
* @param identifier Identifier of child node
* @return Modified child or null if child was not modified.
*/
@Nullable DataTreeCandidateNode getModifiedChild(PathArgument identifier);
/**
* Return the type of modification this node is undergoing.
*
* @return Node modification type.
*/
@Nonnull ModificationType getModificationType();
/**
* Return the after-image of data corresponding to the node.
*
* @return Node data as they will be present in the tree after
* the modification is applied.
*/
@Nonnull Optional<NormalizedNode<?, ?>> getDataAfter();
/**
* Return the before-image of data corresponding to the node.
*
* @return Node data as they were present in the tree before
* the modification was applied.
*/
@Nonnull Optional<NormalizedNode<?, ?>> getDataBefore();
}