⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 walkingiteratorsorted.java

📁 java1.6众多例子参考
💻 JAVA
字号:
/* * Copyright 1999-2004 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *//* * $Id: WalkingIteratorSorted.java,v 1.2.4.1 2005/09/14 19:45:23 jeffsuttor Exp $ */package com.sun.org.apache.xpath.internal.axes;import com.sun.org.apache.xml.internal.dtm.Axis;import com.sun.org.apache.xml.internal.utils.PrefixResolver;import com.sun.org.apache.xpath.internal.compiler.Compiler;/** * This class iterates over set of nodes that needs to be sorted. * @xsl.usage internal */public class WalkingIteratorSorted extends WalkingIterator{    static final long serialVersionUID = -4512512007542368213L;//  /** True if the nodes will be found in document order *///  protected boolean m_inNaturalOrder = false;    /** True if the nodes will be found in document order, and this can    * be determined statically. */  protected boolean m_inNaturalOrderStatic = false;  /**   * Create a WalkingIteratorSorted object.   *   * @param nscontext The namespace context for this iterator,   * should be OK if null.   */  public WalkingIteratorSorted(PrefixResolver nscontext)  {    super(nscontext);  }  /**   * Create a WalkingIterator iterator, including creation   * of step walkers from the opcode list, and call back   * into the Compiler to create predicate expressions.   *   * @param compiler The Compiler which is creating   * this expression.   * @param opPos The position of this iterator in the   * opcode list from the compiler.   * @param shouldLoadWalkers True if walkers should be   * loaded, or false if this is a derived iterator and   * it doesn't wish to load child walkers.   *   * @throws javax.xml.transform.TransformerException   */  WalkingIteratorSorted(          Compiler compiler, int opPos, int analysis, boolean shouldLoadWalkers)            throws javax.xml.transform.TransformerException  {    super(compiler, opPos, analysis, shouldLoadWalkers);  }    /**   * Returns true if all the nodes in the iteration well be returned in document    * order.   *    * @return true as a default.   */  public boolean isDocOrdered()  {    return m_inNaturalOrderStatic;  }      /**   * Tell if the nodeset can be walked in doc order, via static analysis.    *   *   * @return true if the nodeset can be walked in doc order, without sorting.   */  boolean canBeWalkedInNaturalDocOrderStatic()  {    if (null != m_firstWalker)    {      AxesWalker walker = m_firstWalker;      int prevAxis = -1;      boolean prevIsSimpleDownAxis = true;      for(int i = 0; null != walker; i++)      {        int axis = walker.getAxis();                if(walker.isDocOrdered())        {          boolean isSimpleDownAxis = ((axis == Axis.CHILD)                                   || (axis == Axis.SELF)                                   || (axis == Axis.ROOT));          // Catching the filtered list here is only OK because          // FilterExprWalker#isDocOrdered() did the right thing.          if(isSimpleDownAxis || (axis == -1))            walker = walker.getNextWalker();          else          {            boolean isLastWalker = (null == walker.getNextWalker());            if(isLastWalker)            {              if(walker.isDocOrdered() && (axis == Axis.DESCENDANT ||                  axis == Axis.DESCENDANTORSELF || axis == Axis.DESCENDANTSFROMROOT                 || axis == Axis.DESCENDANTSORSELFFROMROOT) || (axis == Axis.ATTRIBUTE))                return true;            }            return false;          }        }        else          return false;      }      return true;    }    return false;  }//  /**//   * NEEDSDOC Method canBeWalkedInNaturalDocOrder //   *//   *//   * NEEDSDOC (canBeWalkedInNaturalDocOrder) @return//   *///  boolean canBeWalkedInNaturalDocOrder()//  {////    if (null != m_firstWalker)//    {//      AxesWalker walker = m_firstWalker;//      int prevAxis = -1;//      boolean prevIsSimpleDownAxis = true;////      for(int i = 0; null != walker; i++)//      {//        int axis = walker.getAxis();//        //        if(walker.isDocOrdered())//        {//          boolean isSimpleDownAxis = ((axis == Axis.CHILD)//                                   || (axis == Axis.SELF)//                                   || (axis == Axis.ROOT));//          // Catching the filtered list here is only OK because//          // FilterExprWalker#isDocOrdered() did the right thing.//          if(isSimpleDownAxis || (axis == -1))//            walker = walker.getNextWalker();//          else//          {//            boolean isLastWalker = (null == walker.getNextWalker());//            if(isLastWalker)//            {//              if(walker.isDocOrdered() && (axis == Axis.DESCENDANT || //                 axis == Axis.DESCENDANTORSELF || axis == Axis.DESCENDANTSFROMROOT//                 || axis == Axis.DESCENDANTSORSELFFROMROOT) || (axis == Axis.ATTRIBUTE))//                return true;//            }//            return false;//          }//        }//        else//          return false;//      }//      return true;//    }//    return false;//  }    /**   * This function is used to perform some extra analysis of the iterator.   *    * @param vars List of QNames that correspond to variables.  This list    * should be searched backwards for the first qualified name that    * corresponds to the variable reference qname.  The position of the    * QName in the vector from the start of the vector will be its position    * in the stack frame (but variables above the globalsTop value will need    * to be offset to the current stack frame).   */  public void fixupVariables(java.util.Vector vars, int globalsSize)  {    super.fixupVariables(vars, globalsSize);    int analysis = getAnalysisBits();    if(WalkerFactory.isNaturalDocOrder(analysis))    {    	m_inNaturalOrderStatic = true;    }    else    {    	m_inNaturalOrderStatic = false;    	// System.out.println("Setting natural doc order to false: "+    	//    WalkerFactory.getAnalysisString(analysis));    }      }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -