package org.opendaylight.yangtools.yang.data.api.schema.tree;
import com.google.common.annotations.Beta;
-import com.google.common.base.Optional;
-import javax.annotation.Nonnull;
+import java.util.Optional;
+import org.eclipse.jdt.annotation.NonNull;
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;
/**
- * A cursor holding a logical position within a {@link DataTreeSnapshot}. It allows
- * operations relative to that position, as well as moving the position up or down
- * the tree.
+ * A cursor holding a logical position within a {@link DataTreeSnapshot}. It allows operations relative to that
+ * position, as well as moving the position up or down the tree. Implementations are expected to be NOT thread-safe.
*/
@Beta
public interface DataTreeSnapshotCursor extends AutoCloseable {
* Move the cursor to the specified child of the current position.
*
* @param child Child identifier
- * @throws BackendFailedException when implementation-specific errors occurs
+ * @throws BackendFailedException when an implementation-specific error occurs
* while servicing the request.
* @throws IllegalArgumentException when specified identifier does not identify
* a valid child, or if that child is not an
* instance of {@link NormalizedNodeContainer}.
*/
- void enter(@Nonnull PathArgument child);
+ void enter(@NonNull PathArgument child);
/**
* Move the cursor to the specified child of the current position. This is
* the equivalent of multiple invocations of {@link #enter(PathArgument)},
- * except the operation is performed atomically.
+ * except the operation is performed all at once.
*
* @param path Nested child identifier
- * @throws BackendFailedException when implementation-specific errors occurs
+ * @throws BackendFailedException when an implementation-specific error occurs
* while servicing the request.
* @throws IllegalArgumentException when specified path does not identify
* a valid child, or if that child is not an
* instance of {@link NormalizedNodeContainer}.
*/
- void enter(@Nonnull PathArgument... path);
+ void enter(@NonNull PathArgument... path);
/**
* Move the cursor to the specified child of the current position. This is
* argument.
*
* @param path Nested child identifier
- * @throws BackendFailedException when implementation-specific errors occurs
+ * @throws BackendFailedException when an implementation-specific error occurs
* while servicing the request.
* @throws IllegalArgumentException when specified path does not identify
* a valid child, or if that child is not an
* instance of {@link NormalizedNodeContainer}.
*/
- void enter(@Nonnull Iterable<PathArgument> path);
+ void enter(@NonNull Iterable<PathArgument> path);
/**
* Move the cursor up to the parent of current position. This is equivalent of
* servicing the request.
* @throws IllegalArgumentException when specified path does not identify a valid child.
*/
- Optional<NormalizedNode<?, ?>> readNode(@Nonnull PathArgument child);
+ Optional<NormalizedNode> readNode(@NonNull PathArgument child);
/**
* Close this cursor. Attempting any further operations on the cursor will lead