File: PrecedingSiblingAxisExpr.java

package info (click to toggle)
lib-xt-java 0.19990725-1
  • links: PTS
  • area: main
  • in suites: potato
  • size: 1,224 kB
  • ctags: 2,133
  • sloc: java: 9,665; makefile: 54; xml: 28
file content (37 lines) | stat: -rw-r--r-- 1,140 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package com.jclark.xsl.expr;

import com.jclark.xsl.om.*;

class PrecedingSiblingAxisExpr extends ReverseAxisExpr {
  public NodeIterator eval(Node node, ExprContext context) throws XSLException {
    return precedingSiblings(node);
  }

  static NodeIterator precedingSiblings(Node node) throws XSLException {
    if (node.getType() == Node.ATTRIBUTE)
      return null;
    Node tem = node.getParent();
    if (tem == null)
      return new SingleNodeIterator(null);
    NodeIterator iter = tem.getChildren();
    tem = iter.next();
    if (tem.equals(node))
      return new SingleNodeIterator(null);
    Node[] nodes = new Node[1];
    int off = nodes.length;
    nodes[--off] = tem;
    for (tem = iter.next(); !tem.equals(node); tem = iter.next()) {
      if (off == 0) {
	Node oldNodes[] = nodes;
	nodes = new Node[oldNodes.length * 2];
	System.arraycopy(oldNodes, 0, nodes, oldNodes.length, oldNodes.length);
	off = oldNodes.length;
      }
      nodes[--off] = tem;
    }
    return new ArrayNodeIterator(nodes, off, nodes.length);
  }
  int getOptimizeFlags() {
    return SINGLE_LEVEL;
  }
}