All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.neo4j.graphdb.TraversalPosition Maven / Gradle / Ivy

/*
 * Copyright (c) 2002-2015 "Neo Technology,"
 * Network Engine for Objects in Lund AB [http://neotechnology.com]
 *
 * This file is part of Neo4j.
 *
 * Neo4j is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package org.neo4j.graphdb;


/**
 * Encapsulates information about the current traversal position.
 *
 * The TraversalPosition is mainly used in
 * {@link StopEvaluator#isStopNode(TraversalPosition)} and
 * {@link ReturnableEvaluator#isReturnableNode(TraversalPosition)} for
 * evaluating whether a position in a traversal is a point where the traversal
 * should stop or if the node at that position is to be part of the result
 * respectively.
 */
/*
 * @deprecated because of the introduction of a new traversal framework,
 * see more information at {@link TraversalDescription} and
 * {@link Traversal} and the new traversal framework's equivalent
 * {@link Path}.
 */
// @Deprecated
public interface TraversalPosition
{
    /**
     * Returns the current node.
     * 
     * @return The current node
     */
    Node currentNode();

    /**
     * Returns the previous node.
     *
     * If this TraversalPosition represents the start node null is
     * returned.
     *
     * @return The previous node, or null
     */
    Node previousNode();

    /**
     * Return the last relationship traversed.
     *
     * If this TraversalPosition represents the start node null is
     * returned.
     *
     * @return The last relationship traversed, or null.
     */
    Relationship lastRelationshipTraversed();

    /**
     * Returns the current traversal depth.
     *
     * The traversal depth is the length of the path taken to reach the current
     * traversal position. This is not necessarily the length of shortest path
     * from the start node to the node at the current position. When traversing
     * {@link Traverser.Order#BREADTH_FIRST breadth first} the depth is the
     * length of the shortest path from the start node to the node at the
     * current position, but when traversing {@link Traverser.Order#DEPTH_FIRST
     * depth first} there might exist shorter paths from the start node to the
     * node at this position.
     *
     * @return The current traversal depth
     */
    int depth();

    /**
     * Returns the number of nodes returned by the traverser so far.
     * 
     * @return The number of returned nodes.
     */
    int returnedNodesCount();

    /**
     * Returns true if the current position is anywhere except on
     * the start node, false if it is on the start node. This is
     * useful because code in {@link StopEvaluator the}
     * {@link ReturnableEvaluator evaluators} usually have to treat the edge
     * case of the start node separately and using this method makes that code a
     * lot cleaner. This allows for much cleaner code where null
     * checks can be avoided for return values from
     * {@link #lastRelationshipTraversed()} and {@link #previousNode()}, such as
     * in this example:
     *
     * 
     * 
     * public boolean {@link StopEvaluator#isStopNode(TraversalPosition) isStopNode}( TraversalPosition currentPos )
     * {
     *     // Stop at nodes reached through a SOME_RELATIONSHIP.
     *     return currentPos.notStartNode()
     *         && currentPos.{@link #lastRelationshipTraversed() lastRelationshipTraversed}().{@link Relationship#isType(RelationshipType) isType}(
     *             {@link RelationshipType MyRelationshipTypes.SOME_RELATIONSHIP} );
     * }
     * 
     * 
* * @return true if the this TraversalPosition is not at the * start node, false if it is. */ boolean notStartNode(); /** * Returns true if the current position is the start node, * false otherwise. This is useful because code in * {@link StopEvaluator the} {@link ReturnableEvaluator evaluators} usually * have to treat the edge case of the start node separately and using this * method makes that code a lot cleaner. This allows for much cleaner code * where null checks can be avoided for return values from * {@link #lastRelationshipTraversed()} and {@link #previousNode()}, such as * in this example: * *
     * 
     * public boolean {@link ReturnableEvaluator#isReturnableNode(TraversalPosition) isReturnableNode}( TraversalPosition currentPos )
     * {
     *     // The start node, and nodes reached through SOME_RELATIONSHIP
     *     // are returnable.
     *     return currentPos.isStartNode()
     *         || currentPos.{@link #lastRelationshipTraversed() lastRelationshipTraversed}().{@link Relationship#isType(RelationshipType) isType}(
     *             {@link RelationshipType MyRelationshipTypes.SOME_RELATIONSHIP} );
     * }
     * 
     * 
* * @return true if the this TraversalPosition is at the start * node, false if it is not. */ boolean isStartNode(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy