19f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson/*
29f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * Licensed to the Apache Software Foundation (ASF) under one
39f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * or more contributor license agreements. See the NOTICE file
49f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * distributed with this work for additional information
59f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * regarding copyright ownership. The ASF licenses this file
69f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * to you under the Apache License, Version 2.0 (the  "License");
79f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * you may not use this file except in compliance with the License.
89f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * You may obtain a copy of the License at
99f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson *
109f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson *     http://www.apache.org/licenses/LICENSE-2.0
119f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson *
129f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * Unless required by applicable law or agreed to in writing, software
139f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * distributed under the License is distributed on an "AS IS" BASIS,
149f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
159f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * See the License for the specific language governing permissions and
169f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * limitations under the License.
179f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson */
189f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson/*
199f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * $Id: WalkingIteratorSorted.java 468655 2006-10-28 07:12:06Z minchau $
209f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson */
219f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilsonpackage org.apache.xpath.axes;
229f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
239f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilsonimport org.apache.xml.dtm.Axis;
249f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilsonimport org.apache.xml.utils.PrefixResolver;
259f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilsonimport org.apache.xpath.compiler.Compiler;
269f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
279f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson/**
289f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * This class iterates over set of nodes that needs to be sorted.
299f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson * @xsl.usage internal
309f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson */
319f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilsonpublic class WalkingIteratorSorted extends WalkingIterator
329f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson{
339f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    static final long serialVersionUID = -4512512007542368213L;
349f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
359f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//  /** True if the nodes will be found in document order */
369f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//  protected boolean m_inNaturalOrder = false;
379f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
389f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  /** True if the nodes will be found in document order, and this can
399f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * be determined statically. */
409f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  protected boolean m_inNaturalOrderStatic = false;
419f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
429f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  /**
439f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * Create a WalkingIteratorSorted object.
449f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
459f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @param nscontext The namespace context for this iterator,
469f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * should be OK if null.
479f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   */
489f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  public WalkingIteratorSorted(PrefixResolver nscontext)
499f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  {
509f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    super(nscontext);
519f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  }
529f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
539f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  /**
549f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * Create a WalkingIterator iterator, including creation
559f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * of step walkers from the opcode list, and call back
569f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * into the Compiler to create predicate expressions.
579f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
589f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @param compiler The Compiler which is creating
599f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * this expression.
609f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @param opPos The position of this iterator in the
619f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * opcode list from the compiler.
629f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @param shouldLoadWalkers True if walkers should be
639f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * loaded, or false if this is a derived iterator and
649f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * it doesn't wish to load child walkers.
659f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
669f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @throws javax.xml.transform.TransformerException
679f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   */
689f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  WalkingIteratorSorted(
699f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          Compiler compiler, int opPos, int analysis, boolean shouldLoadWalkers)
709f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            throws javax.xml.transform.TransformerException
719f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  {
729f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    super(compiler, opPos, analysis, shouldLoadWalkers);
739f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  }
749f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
759f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  /**
769f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * Returns true if all the nodes in the iteration well be returned in document
779f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * order.
789f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
799f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @return true as a default.
809f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   */
819f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  public boolean isDocOrdered()
829f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  {
839f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    return m_inNaturalOrderStatic;
849f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  }
859f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
869f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
879f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  /**
889f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * Tell if the nodeset can be walked in doc order, via static analysis.
899f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
909f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
919f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @return true if the nodeset can be walked in doc order, without sorting.
929f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   */
939f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  boolean canBeWalkedInNaturalDocOrderStatic()
949f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  {
959f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
969f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    if (null != m_firstWalker)
979f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    {
989f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      AxesWalker walker = m_firstWalker;
999f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      int prevAxis = -1;
1009f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      boolean prevIsSimpleDownAxis = true;
1019f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
1029f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      for(int i = 0; null != walker; i++)
1039f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      {
1049f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson        int axis = walker.getAxis();
1059f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
1069f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson        if(walker.isDocOrdered())
1079f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson        {
1089f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          boolean isSimpleDownAxis = ((axis == Axis.CHILD)
1099f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson                                   || (axis == Axis.SELF)
1109f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson                                   || (axis == Axis.ROOT));
1119f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          // Catching the filtered list here is only OK because
1129f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          // FilterExprWalker#isDocOrdered() did the right thing.
1139f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          if(isSimpleDownAxis || (axis == -1))
1149f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            walker = walker.getNextWalker();
1159f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          else
1169f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          {
1179f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            boolean isLastWalker = (null == walker.getNextWalker());
1189f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            if(isLastWalker)
1199f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            {
1209f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson              if(walker.isDocOrdered() && (axis == Axis.DESCENDANT ||
1219f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson                 axis == Axis.DESCENDANTORSELF || axis == Axis.DESCENDANTSFROMROOT
1229f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson                 || axis == Axis.DESCENDANTSORSELFFROMROOT) || (axis == Axis.ATTRIBUTE))
1239f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson                return true;
1249f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            }
1259f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson            return false;
1269f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          }
1279f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson        }
1289f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson        else
1299f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson          return false;
1309f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      }
1319f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson      return true;
1329f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    }
1339f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    return false;
1349f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  }
1359f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
1369f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
1379f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//  /**
1389f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//   * NEEDSDOC Method canBeWalkedInNaturalDocOrder
1399f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//   *
1409f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//   *
1419f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//   * NEEDSDOC (canBeWalkedInNaturalDocOrder) @return
1429f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//   */
1439f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//  boolean canBeWalkedInNaturalDocOrder()
1449f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//  {
1459f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//
1469f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//    if (null != m_firstWalker)
1479f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//    {
1489f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      AxesWalker walker = m_firstWalker;
1499f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      int prevAxis = -1;
1509f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      boolean prevIsSimpleDownAxis = true;
1519f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//
1529f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      for(int i = 0; null != walker; i++)
1539f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      {
1549f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//        int axis = walker.getAxis();
1559f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//
1569f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//        if(walker.isDocOrdered())
1579f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//        {
1589f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          boolean isSimpleDownAxis = ((axis == Axis.CHILD)
1599f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//                                   || (axis == Axis.SELF)
1609f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//                                   || (axis == Axis.ROOT));
1619f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          // Catching the filtered list here is only OK because
1629f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          // FilterExprWalker#isDocOrdered() did the right thing.
1639f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          if(isSimpleDownAxis || (axis == -1))
1649f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//            walker = walker.getNextWalker();
1659f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          else
1669f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          {
1679f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//            boolean isLastWalker = (null == walker.getNextWalker());
1689f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//            if(isLastWalker)
1699f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//            {
1709f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//              if(walker.isDocOrdered() && (axis == Axis.DESCENDANT ||
1719f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//                 axis == Axis.DESCENDANTORSELF || axis == Axis.DESCENDANTSFROMROOT
1729f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//                 || axis == Axis.DESCENDANTSORSELFFROMROOT) || (axis == Axis.ATTRIBUTE))
1739f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//                return true;
1749f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//            }
1759f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//            return false;
1769f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          }
1779f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//        }
1789f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//        else
1799f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//          return false;
1809f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      }
1819f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//      return true;
1829f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//    }
1839f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//    return false;
1849f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson//  }
1859f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
1869f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  /**
1879f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * This function is used to perform some extra analysis of the iterator.
1889f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   *
1899f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * @param vars List of QNames that correspond to variables.  This list
1909f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * should be searched backwards for the first qualified name that
1919f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * corresponds to the variable reference qname.  The position of the
1929f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * QName in the vector from the start of the vector will be its position
1939f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * in the stack frame (but variables above the globalsTop value will need
1949f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   * to be offset to the current stack frame).
1959f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson   */
1969f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  public void fixupVariables(java.util.Vector vars, int globalsSize)
1979f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  {
1989f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    super.fixupVariables(vars, globalsSize);
1999f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
2009f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    int analysis = getAnalysisBits();
2019f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    if(WalkerFactory.isNaturalDocOrder(analysis))
2029f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    {
2039f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    	m_inNaturalOrderStatic = true;
2049f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    }
2059f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    else
2069f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    {
2079f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    	m_inNaturalOrderStatic = false;
2089f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    	// System.out.println("Setting natural doc order to false: "+
2099f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    	//    WalkerFactory.getAnalysisString(analysis));
2109f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson    }
2119f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
2129f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson  }
2139f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson
2149f8118474e9513f7a5b7d2a05e4a0fb15d1a6569Jesse Wilson}
215