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

io.sirix.axis.PostOrderAxis Maven / Gradle / Ivy

/**
 * Copyright (c) 2011, University of Konstanz, Distributed Systems Group All rights reserved.
 * 

* Redistribution and use in source and binary forms, with or without modification, are permitted * provided that the following conditions are met: * Redistributions of source code must retain the * above copyright notice, this list of conditions and the following disclaimer. * Redistributions * in binary form must reproduce the above copyright notice, this list of conditions and the * following disclaimer in the documentation and/or other materials provided with the distribution. * * Neither the name of the University of Konstanz nor the names of its contributors may be used to * endorse or promote products derived from this software without specific prior written permission. *

* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ package io.sirix.axis; import io.sirix.api.NodeCursor; import io.sirix.settings.Fixed; /** *

* Iterate over the whole tree starting with the last node. *

*/ public final class PostOrderAxis extends AbstractAxis { /** * Determines if transaction moved to the parent before. */ private boolean movedToParent; /** * Determines if current key is the start node key before the traversal. */ private boolean isStartKey; /** * Constructor initializing internal state. * * @param cursor cursor to iterate with */ public PostOrderAxis(final NodeCursor cursor) { super(cursor); } /** * Constructor initializing internal state. * * @param cursor cursor to iterate with */ public PostOrderAxis(final NodeCursor cursor, final IncludeSelf includeSelf) { super(cursor, includeSelf); } @Override public void reset(final long nodeKey) { super.reset(nodeKey); movedToParent = false; isStartKey = false; } @Override protected long nextKey() { final NodeCursor cursor = getCursor(); // No subtree. if (!cursor.hasFirstChild() && cursor.getNodeKey() == getStartKey() || isStartKey) { if (!isStartKey && includeSelf() == IncludeSelf.YES) { isStartKey = true; return cursor.getNodeKey(); } else { return done(); } } final long currKey = cursor.getNodeKey(); // Move down in the tree if it hasn't moved down before. if ((!movedToParent && cursor.hasFirstChild()) || (cursor.hasRightSibling() && (cursor.moveToRightSibling()))) { while (cursor.hasFirstChild()) { cursor.moveToFirstChild(); } final long key = cursor.getNodeKey(); cursor.moveTo(currKey); return key; } // Move to the right sibling or parent node after walking down. long key = 0; if (cursor.hasRightSibling()) { key = cursor.getRightSiblingKey(); } else { key = cursor.getParentKey(); movedToParent = true; } // Stop traversal if needed. if (key == Fixed.NULL_NODE_KEY.getStandardProperty()) { return key; } // Traversal is at start key. if (key == getStartKey()) { if (includeSelf() == IncludeSelf.YES) { isStartKey = true; return key; } else { return done(); } } // Move back to current node. cursor.moveTo(currKey); return key; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy