/*
* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
* Use of this file is governed by the BSD 3-clause license that
* can be found in the LICENSE.txt file in the project root.
*/
package org.antlr.v4.runtime.tree.xpath;
import org.antlr.v4.runtime.tree.ParseTree;
import java.util.Collection;
public abstract class XPathElement {
protected String nodeName;
protected boolean invert;
Construct element like /ID
or ID
or /*
etc... op is null if just node /** Construct element like {@code /ID} or {@code ID} or {@code /*} etc...
* op is null if just node
*/
public XPathElement(String nodeName) {
this.nodeName = nodeName;
}
Given tree rooted at t
return all nodes matched by this path element. /**
* Given tree rooted at {@code t} return all nodes matched by this path
* element.
*/
public abstract Collection<ParseTree> evaluate(ParseTree t);
@Override
public String toString() {
String inv = invert ? "!" : "";
return getClass().getSimpleName()+"["+inv+nodeName+"]";
}
}