fromprevioussibling.java

来自「RESIN 3.2 最新源码」· Java 代码 · 共 158 行

JAVA
158
字号
/* * Copyright (c) 1998-2008 Caucho Technology -- all rights reserved * * This file is part of Resin(R) Open Source * * Each copy or derived work must preserve the copyright notice and this * notice unmodified. * * Resin Open Source 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 2 of the License, or * (at your option) any later version. * * Resin Open Source 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, or any warranty * of NON-INFRINGEMENT.  See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with Resin Open Source; if not, write to the *   Free SoftwareFoundation, Inc. *   59 Temple Place, Suite 330 *   Boston, MA 02111-1307  USA * * @author Scott Ferguson */package com.caucho.xpath.pattern;import com.caucho.xpath.Env;import com.caucho.xpath.ExprEnvironment;import com.caucho.xpath.XPathException;import org.w3c.dom.Node;/** * matches if we can find a following sibling matching the parent pattern. */public class FromPreviousSibling extends Axis {  public FromPreviousSibling(AbstractPattern parent)  {    super(parent);    if (parent == null)      throw new RuntimeException();  }  /**   * matches if we can find a following sibling that matches the parent.   *   * @param node the current node   * @param env the variable environment   *   * @return true if the pattern matches   */  public boolean match(Node node, ExprEnvironment env)    throws XPathException  {    if (node == null)      return false;    for (node = node.getNextSibling();	 node != null;	 node = node.getNextSibling()) {      if (_parent.match(node, env))	return true;    }        return false;  }  /**   * preceding-sibling's iterator is in reverse document order.   */  public boolean isAscending()  {    return false;  }  /**   * Returns true if the pattern returns unique values.   */  public boolean isUnique()  {    if (_parent == null)      return true;    else      return _parent.isSingleSelect();  }  /**   * Returns the first node in the selection order.   *   * @param node the current node   *   * @return the first node   */  public Node firstNode(Node node, ExprEnvironment env)  {    return node.getPreviousSibling();  }  /**   * Returns the next node in the selection order.   *   * @param node the current node   * @param lastNode the last node   *   * @return the next node   */  public Node nextNode(Node node, Node lastNOde)  {    return node.getPreviousSibling();  }  /**   * The count of nodes between the test-node and the axis.   *   * @param node the current node   * @param env the variable environment   */  public int position(Node node, Env env, AbstractPattern pattern)    throws XPathException  {    int index = env.getPositionIndex();    int count = 1;    while ((node = node.getNextSibling()) != null) {      if (_parent.match(node, env)) {        if (--index <= 0) {          // Test if there are more possible roots.          for (node = node.getNextSibling();               node != null;               node = node.getNextSibling()) {            if (_parent.match(node, env)) {              env.setMorePositions(true);              break;            }          }          return count;        }      }      if (pattern.match(node, env))	count++;    }    return count;  }  public String toString()  {    return getPrefix() + "preceding-sibling::";  }}

⌨️ 快捷键说明

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