Java Code Examples for com.sun.org.apache.xml.internal.dtm.DTMIterator#FILTER_ACCEPT

The following examples show how to use com.sun.org.apache.xml.internal.dtm.DTMIterator#FILTER_ACCEPT . You can vote up the ones you like or vote down the ones you don't like, and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: FilterExprWalker.java    From openjdk-jdk8u-backup with GNU General Public License v2.0 6 votes vote down vote up
/**
 * This method needs to override AxesWalker.acceptNode because FilterExprWalkers
 * don't need to, and shouldn't, do a node test.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{

  try
  {
    if (getPredicateCount() > 0)
    {
      countProximityPosition(0);

      if (!executePredicates(n, m_lpi.getXPathContext()))
        return DTMIterator.FILTER_SKIP;
    }

    return DTMIterator.FILTER_ACCEPT;
  }
  catch (javax.xml.transform.TransformerException se)
  {
    throw new RuntimeException(se.getMessage());
  }
}
 
Example 2
Source File: FilterExprWalker.java    From jdk8u60 with GNU General Public License v2.0 6 votes vote down vote up
/**
 * This method needs to override AxesWalker.acceptNode because FilterExprWalkers
 * don't need to, and shouldn't, do a node test.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{

  try
  {
    if (getPredicateCount() > 0)
    {
      countProximityPosition(0);

      if (!executePredicates(n, m_lpi.getXPathContext()))
        return DTMIterator.FILTER_SKIP;
    }

    return DTMIterator.FILTER_ACCEPT;
  }
  catch (javax.xml.transform.TransformerException se)
  {
    throw new RuntimeException(se.getMessage());
  }
}
 
Example 3
Source File: FilterIterator.java    From openjdk-jdk8u-backup with GNU General Public License v2.0 5 votes vote down vote up
public int next() {
    int node;
    while ((node = _source.next()) != END) {
        if (_filter.acceptNode(node, DTMFilter.SHOW_ALL) == DTMIterator.FILTER_ACCEPT) {
            return returnNode(node);
        }
    }
    return END;
}
 
Example 4
Source File: UnionChildIterator.java    From openjdk-8 with GNU General Public License v2.0 5 votes vote down vote up
/**
 * Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{
  XPathContext xctxt = getXPathContext();
  try
  {
    xctxt.pushCurrentNode(n);
    for (int i = 0; i < m_nodeTests.length; i++)
    {
      PredicatedNodeTest pnt = m_nodeTests[i];
      XObject score = pnt.execute(xctxt, n);
      if (score != NodeTest.SCORE_NONE)
      {
        // Note that we are assuming there are no positional predicates!
        if (pnt.getPredicateCount() > 0)
        {
          if (pnt.executePredicates(n, xctxt))
            return DTMIterator.FILTER_ACCEPT;
        }
        else
          return DTMIterator.FILTER_ACCEPT;

      }
    }
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
  }
  return DTMIterator.FILTER_SKIP;
}
 
Example 5
Source File: FilterIterator.java    From jdk8u60 with GNU General Public License v2.0 5 votes vote down vote up
public int next() {
    int node;
    while ((node = _source.next()) != END) {
        if (_filter.acceptNode(node, DTMFilter.SHOW_ALL) == DTMIterator.FILTER_ACCEPT) {
            return returnNode(node);
        }
    }
    return END;
}
 
Example 6
Source File: UnionChildIterator.java    From jdk8u60 with GNU General Public License v2.0 5 votes vote down vote up
/**
 * Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{
  XPathContext xctxt = getXPathContext();
  try
  {
    xctxt.pushCurrentNode(n);
    for (int i = 0; i < m_nodeTests.length; i++)
    {
      PredicatedNodeTest pnt = m_nodeTests[i];
      XObject score = pnt.execute(xctxt, n);
      if (score != NodeTest.SCORE_NONE)
      {
        // Note that we are assuming there are no positional predicates!
        if (pnt.getPredicateCount() > 0)
        {
          if (pnt.executePredicates(n, xctxt))
            return DTMIterator.FILTER_ACCEPT;
        }
        else
          return DTMIterator.FILTER_ACCEPT;

      }
    }
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
  }
  return DTMIterator.FILTER_SKIP;
}
 
Example 7
Source File: UnionChildIterator.java    From TencentKona-8 with GNU General Public License v2.0 5 votes vote down vote up
/**
 * Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{
  XPathContext xctxt = getXPathContext();
  try
  {
    xctxt.pushCurrentNode(n);
    for (int i = 0; i < m_nodeTests.length; i++)
    {
      PredicatedNodeTest pnt = m_nodeTests[i];
      XObject score = pnt.execute(xctxt, n);
      if (score != NodeTest.SCORE_NONE)
      {
        // Note that we are assuming there are no positional predicates!
        if (pnt.getPredicateCount() > 0)
        {
          if (pnt.executePredicates(n, xctxt))
            return DTMIterator.FILTER_ACCEPT;
        }
        else
          return DTMIterator.FILTER_ACCEPT;

      }
    }
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
  }
  return DTMIterator.FILTER_SKIP;
}
 
Example 8
Source File: UnionChildIterator.java    From Bytecoder with Apache License 2.0 5 votes vote down vote up
/**
 * Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{
  XPathContext xctxt = getXPathContext();
  try
  {
    xctxt.pushCurrentNode(n);
    for (int i = 0; i < m_nodeTests.length; i++)
    {
      PredicatedNodeTest pnt = m_nodeTests[i];
      XObject score = pnt.execute(xctxt, n);
      if (score != NodeTest.SCORE_NONE)
      {
        // Note that we are assuming there are no positional predicates!
        if (pnt.getPredicateCount() > 0)
        {
          if (pnt.executePredicates(n, xctxt))
            return DTMIterator.FILTER_ACCEPT;
        }
        else
          return DTMIterator.FILTER_ACCEPT;

      }
    }
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
  }
  return DTMIterator.FILTER_SKIP;
}
 
Example 9
Source File: FilterIterator.java    From openjdk-8 with GNU General Public License v2.0 5 votes vote down vote up
public int next() {
    int node;
    while ((node = _source.next()) != END) {
        if (_filter.acceptNode(node, DTMFilter.SHOW_ALL) == DTMIterator.FILTER_ACCEPT) {
            return returnNode(node);
        }
    }
    return END;
}
 
Example 10
Source File: FilterIterator.java    From openjdk-jdk8u with GNU General Public License v2.0 5 votes vote down vote up
public int next() {
    int node;
    while ((node = _source.next()) != END) {
        if (_filter.acceptNode(node, DTMFilter.SHOW_ALL) == DTMIterator.FILTER_ACCEPT) {
            return returnNode(node);
        }
    }
    return END;
}
 
Example 11
Source File: PredicatedNodeTest.java    From hottub with GNU General Public License v2.0 5 votes vote down vote up
/**
 *  Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{

  XPathContext xctxt = m_lpi.getXPathContext();

  try
  {
    xctxt.pushCurrentNode(n);

    XObject score = execute(xctxt, n);

    // System.out.println("\n::acceptNode - score: "+score.num()+"::");
    if (score != NodeTest.SCORE_NONE)
    {
      if (getPredicateCount() > 0)
      {
        countProximityPosition(0);

        if (!executePredicates(n, xctxt))
          return DTMIterator.FILTER_SKIP;
      }

      return DTMIterator.FILTER_ACCEPT;
    }
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
  }

  return DTMIterator.FILTER_SKIP;
}
 
Example 12
Source File: FilterIterator.java    From hottub with GNU General Public License v2.0 5 votes vote down vote up
public int next() {
    int node;
    while ((node = _source.next()) != END) {
        if (_filter.acceptNode(node, DTMFilter.SHOW_ALL) == DTMIterator.FILTER_ACCEPT) {
            return returnNode(node);
        }
    }
    return END;
}
 
Example 13
Source File: PredicatedNodeTest.java    From openjdk-jdk8u with GNU General Public License v2.0 5 votes vote down vote up
/**
 *  Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n)
{

  XPathContext xctxt = m_lpi.getXPathContext();

  try
  {
    xctxt.pushCurrentNode(n);

    XObject score = execute(xctxt, n);

    // System.out.println("\n::acceptNode - score: "+score.num()+"::");
    if (score != NodeTest.SCORE_NONE)
    {
      if (getPredicateCount() > 0)
      {
        countProximityPosition(0);

        if (!executePredicates(n, xctxt))
          return DTMIterator.FILTER_SKIP;
      }

      return DTMIterator.FILTER_ACCEPT;
    }
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
  }

  return DTMIterator.FILTER_SKIP;
}
 
Example 14
Source File: MatchPatternIterator.java    From TencentKona-8 with GNU General Public License v2.0 4 votes vote down vote up
/**
 *  Returns the next node in the set and advances the position of the
 * iterator in the set. After a NodeIterator is created, the first call
 * to nextNode() returns the first node in the set.
 * @return  The next <code>Node</code> in the set being iterated over, or
 *   <code>null</code> if there are no more members in that set.
 */
public int nextNode()
{
      if(m_foundLast)
              return DTM.NULL;

  int next;

  com.sun.org.apache.xpath.internal.VariableStack vars;
  int savedStart;
  if (-1 != m_stackFrame)
  {
    vars = m_execContext.getVarStack();

    // These three statements need to be combined into one operation.
    savedStart = vars.getStackFrame();

    vars.setStackFrame(m_stackFrame);
  }
  else
  {
    // Yuck.  Just to shut up the compiler!
    vars = null;
    savedStart = 0;
  }

  try
  {
    if(DEBUG)
      System.out.println("m_pattern"+m_pattern.toString());

    do
    {
      next = getNextNode();

      if (DTM.NULL != next)
      {
        if(DTMIterator.FILTER_ACCEPT == acceptNode(next, m_execContext))
          break;
        else
          continue;
      }
      else
        break;
    }
    while (next != DTM.NULL);

    if (DTM.NULL != next)
    {
      if(DEBUG)
      {
        System.out.println("next: "+next);
        System.out.println("name: "+m_cdtm.getNodeName(next));
      }
      incrementCurrentPos();

      return next;
    }
    else
    {
      m_foundLast = true;

      return DTM.NULL;
    }
  }
  finally
  {
    if (-1 != m_stackFrame)
    {
      // These two statements need to be combined into one operation.
      vars.setStackFrame(savedStart);
    }
  }

}
 
Example 15
Source File: MatchPatternIterator.java    From openjdk-jdk8u-backup with GNU General Public License v2.0 4 votes vote down vote up
/**
 *  Returns the next node in the set and advances the position of the
 * iterator in the set. After a NodeIterator is created, the first call
 * to nextNode() returns the first node in the set.
 * @return  The next <code>Node</code> in the set being iterated over, or
 *   <code>null</code> if there are no more members in that set.
 */
public int nextNode()
{
      if(m_foundLast)
              return DTM.NULL;

  int next;

  com.sun.org.apache.xpath.internal.VariableStack vars;
  int savedStart;
  if (-1 != m_stackFrame)
  {
    vars = m_execContext.getVarStack();

    // These three statements need to be combined into one operation.
    savedStart = vars.getStackFrame();

    vars.setStackFrame(m_stackFrame);
  }
  else
  {
    // Yuck.  Just to shut up the compiler!
    vars = null;
    savedStart = 0;
  }

  try
  {
    if(DEBUG)
      System.out.println("m_pattern"+m_pattern.toString());

    do
    {
      next = getNextNode();

      if (DTM.NULL != next)
      {
        if(DTMIterator.FILTER_ACCEPT == acceptNode(next, m_execContext))
          break;
        else
          continue;
      }
      else
        break;
    }
    while (next != DTM.NULL);

    if (DTM.NULL != next)
    {
      if(DEBUG)
      {
        System.out.println("next: "+next);
        System.out.println("name: "+m_cdtm.getNodeName(next));
      }
      incrementCurrentPos();

      return next;
    }
    else
    {
      m_foundLast = true;

      return DTM.NULL;
    }
  }
  finally
  {
    if (-1 != m_stackFrame)
    {
      // These two statements need to be combined into one operation.
      vars.setStackFrame(savedStart);
    }
  }

}
 
Example 16
Source File: DescendantIterator.java    From jdk1.8-source-analysis with Apache License 2.0 4 votes vote down vote up
/**
 *  Returns the next node in the set and advances the position of the
 * iterator in the set. After a NodeIterator is created, the first call
 * to nextNode() returns the first node in the set.
 *
 * @return  The next <code>Node</code> in the set being iterated over, or
 *   <code>null</code> if there are no more members in that set.
 *
 * @throws DOMException
 *    INVALID_STATE_ERR: Raised if this method is called after the
 *   <code>detach</code> method was invoked.
 */
public int nextNode()
{
      if(m_foundLast)
              return DTM.NULL;

  if(DTM.NULL == m_lastFetched)
  {
    resetProximityPositions();
  }

  int next;

  com.sun.org.apache.xpath.internal.VariableStack vars;
  int savedStart;
  if (-1 != m_stackFrame)
  {
    vars = m_execContext.getVarStack();

    // These three statements need to be combined into one operation.
    savedStart = vars.getStackFrame();

    vars.setStackFrame(m_stackFrame);
  }
  else
  {
    // Yuck.  Just to shut up the compiler!
    vars = null;
    savedStart = 0;
  }

  try
  {
    do
    {
      if(0 == m_extendedTypeID)
      {
        next = m_lastFetched = (DTM.NULL == m_lastFetched)
                     ? m_traverser.first(m_context)
                     : m_traverser.next(m_context, m_lastFetched);
      }
      else
      {
        next = m_lastFetched = (DTM.NULL == m_lastFetched)
                     ? m_traverser.first(m_context, m_extendedTypeID)
                     : m_traverser.next(m_context, m_lastFetched,
                                        m_extendedTypeID);
      }

      if (DTM.NULL != next)
      {
        if(DTMIterator.FILTER_ACCEPT == acceptNode(next))
          break;
        else
          continue;
      }
      else
        break;
    }
    while (next != DTM.NULL);

    if (DTM.NULL != next)
    {
      m_pos++;
      return next;
    }
    else
    {
      m_foundLast = true;

      return DTM.NULL;
    }
  }
  finally
  {
    if (-1 != m_stackFrame)
    {
      // These two statements need to be combined into one operation.
      vars.setStackFrame(savedStart);
    }
  }
}
 
Example 17
Source File: MatchPatternIterator.java    From openjdk-jdk9 with GNU General Public License v2.0 4 votes vote down vote up
/**
 *  Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n, XPathContext xctxt)
{

  try
  {
    xctxt.pushCurrentNode(n);
    xctxt.pushIteratorRoot(m_context);
    if(DEBUG)
    {
      System.out.println("traverser: "+m_traverser);
      System.out.print("node: "+n);
      System.out.println(", "+m_cdtm.getNodeName(n));
      // if(m_cdtm.getNodeName(n).equals("near-east"))
      System.out.println("pattern: "+m_pattern.toString());
      m_pattern.debugWhatToShow(m_pattern.getWhatToShow());
    }

    XObject score = m_pattern.execute(xctxt);

    if(DEBUG)
    {
      // System.out.println("analysis: "+Integer.toBinaryString(m_analysis));
      System.out.println("score: "+score);
      System.out.println("skip: "+(score == NodeTest.SCORE_NONE));
    }

    // System.out.println("\n::acceptNode - score: "+score.num()+"::");
    return (score == NodeTest.SCORE_NONE) ? DTMIterator.FILTER_SKIP
                  : DTMIterator.FILTER_ACCEPT;
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
    xctxt.popIteratorRoot();
  }

}
 
Example 18
Source File: DescendantIterator.java    From openjdk-8-source with GNU General Public License v2.0 4 votes vote down vote up
/**
 *  Returns the next node in the set and advances the position of the
 * iterator in the set. After a NodeIterator is created, the first call
 * to nextNode() returns the first node in the set.
 *
 * @return  The next <code>Node</code> in the set being iterated over, or
 *   <code>null</code> if there are no more members in that set.
 *
 * @throws DOMException
 *    INVALID_STATE_ERR: Raised if this method is called after the
 *   <code>detach</code> method was invoked.
 */
public int nextNode()
{
      if(m_foundLast)
              return DTM.NULL;

  if(DTM.NULL == m_lastFetched)
  {
    resetProximityPositions();
  }

  int next;

  com.sun.org.apache.xpath.internal.VariableStack vars;
  int savedStart;
  if (-1 != m_stackFrame)
  {
    vars = m_execContext.getVarStack();

    // These three statements need to be combined into one operation.
    savedStart = vars.getStackFrame();

    vars.setStackFrame(m_stackFrame);
  }
  else
  {
    // Yuck.  Just to shut up the compiler!
    vars = null;
    savedStart = 0;
  }

  try
  {
    do
    {
      if(0 == m_extendedTypeID)
      {
        next = m_lastFetched = (DTM.NULL == m_lastFetched)
                     ? m_traverser.first(m_context)
                     : m_traverser.next(m_context, m_lastFetched);
      }
      else
      {
        next = m_lastFetched = (DTM.NULL == m_lastFetched)
                     ? m_traverser.first(m_context, m_extendedTypeID)
                     : m_traverser.next(m_context, m_lastFetched,
                                        m_extendedTypeID);
      }

      if (DTM.NULL != next)
      {
        if(DTMIterator.FILTER_ACCEPT == acceptNode(next))
          break;
        else
          continue;
      }
      else
        break;
    }
    while (next != DTM.NULL);

    if (DTM.NULL != next)
    {
      m_pos++;
      return next;
    }
    else
    {
      m_foundLast = true;

      return DTM.NULL;
    }
  }
  finally
  {
    if (-1 != m_stackFrame)
    {
      // These two statements need to be combined into one operation.
      vars.setStackFrame(savedStart);
    }
  }
}
 
Example 19
Source File: BasicTestIterator.java    From jdk1.8-source-analysis with Apache License 2.0 4 votes vote down vote up
/**
 *  Returns the next node in the set and advances the position of the
 * iterator in the set. After a NodeIterator is created, the first call
 * to nextNode() returns the first node in the set.
 *
 * @return  The next <code>Node</code> in the set being iterated over, or
 *   <code>null</code> if there are no more members in that set.
 */
public int nextNode()
{
      if(m_foundLast)
      {
              m_lastFetched = DTM.NULL;
              return DTM.NULL;
      }

  if(DTM.NULL == m_lastFetched)
  {
    resetProximityPositions();
  }

  int next;

  com.sun.org.apache.xpath.internal.VariableStack vars;
  int savedStart;
  if (-1 != m_stackFrame)
  {
    vars = m_execContext.getVarStack();

    // These three statements need to be combined into one operation.
    savedStart = vars.getStackFrame();

    vars.setStackFrame(m_stackFrame);
  }
  else
  {
    // Yuck.  Just to shut up the compiler!
    vars = null;
    savedStart = 0;
  }

  try
  {
    do
    {
      next = getNextNode();

      if (DTM.NULL != next)
      {
        if(DTMIterator.FILTER_ACCEPT == acceptNode(next))
          break;
        else
          continue;
      }
      else
        break;
    }
    while (next != DTM.NULL);

    if (DTM.NULL != next)
    {
      m_pos++;
      return next;
    }
    else
    {
      m_foundLast = true;

      return DTM.NULL;
    }
  }
  finally
  {
    if (-1 != m_stackFrame)
    {
      // These two statements need to be combined into one operation.
      vars.setStackFrame(savedStart);
    }
  }
}
 
Example 20
Source File: MatchPatternIterator.java    From JDKSourceCode1.8 with MIT License 4 votes vote down vote up
/**
 *  Test whether a specified node is visible in the logical view of a
 * TreeWalker or NodeIterator. This function will be called by the
 * implementation of TreeWalker and NodeIterator; it is not intended to
 * be called directly from user code.
 * @param n  The node to check to see if it passes the filter or not.
 * @return  a constant to determine whether the node is accepted,
 *   rejected, or skipped, as defined  above .
 */
public short acceptNode(int n, XPathContext xctxt)
{

  try
  {
    xctxt.pushCurrentNode(n);
    xctxt.pushIteratorRoot(m_context);
    if(DEBUG)
    {
      System.out.println("traverser: "+m_traverser);
      System.out.print("node: "+n);
      System.out.println(", "+m_cdtm.getNodeName(n));
      // if(m_cdtm.getNodeName(n).equals("near-east"))
      System.out.println("pattern: "+m_pattern.toString());
      m_pattern.debugWhatToShow(m_pattern.getWhatToShow());
    }

    XObject score = m_pattern.execute(xctxt);

    if(DEBUG)
    {
      // System.out.println("analysis: "+Integer.toBinaryString(m_analysis));
      System.out.println("score: "+score);
      System.out.println("skip: "+(score == NodeTest.SCORE_NONE));
    }

    // System.out.println("\n::acceptNode - score: "+score.num()+"::");
    return (score == NodeTest.SCORE_NONE) ? DTMIterator.FILTER_SKIP
                  : DTMIterator.FILTER_ACCEPT;
  }
  catch (javax.xml.transform.TransformerException se)
  {

    // TODO: Fix this.
    throw new RuntimeException(se.getMessage());
  }
  finally
  {
    xctxt.popCurrentNode();
    xctxt.popIteratorRoot();
  }

}