Changes for version 0.004 - 2013-03-10
- added . as a non-terminal character not requiring an escape
- refactored grammar a little to reduce repetition
- refactored methods to reverse order of TPath::Index and collections in parameters so as to reduce use of undef
- removed some redundant steps
Modules
general purpose path languages for trees
handles evaluating an attribute for a particular node
compares an attribute value to another value
a collection of attributes beyond the standard set
the standard collection of attributes available to any forester by default
takes ASTs and returns compiled TPath::Expression objects
a compiled TPath expression
a generator of TPath expressions for a particular class of nodes
parses TPath expressions into ASTs
general purpose path languages for trees
role of log-like things
interface of square bracket sub-expressions in TPath expressions
implements the [@foo] in //a/b[@foo]
implements the [@foo = 1] in //a/b[@foo = 1]
implements the [@foo or @bar ] in //a/b[@foo or @bar]
implements the [c] in //a/b[c]
implements the [0] in //a/b[0]
an interface for classes that select nodes from a candidate collection
TPath::Selector that implements id(foo)
TPath::Selector that implements ..
TPath::Selector that implements .
role of selectors that apply some test to a node to select it
handles //* expression
handles //@foo expression
handles //~foo~ expression
handles //foo expression
handles /ancestor::@foo or /preceding::@foo where this is not the first step in the path, or ancestor::@foo, etc.
handles /ancestor::~foo~ or /preceding::~foo~ where this is not the first step in the path, or ancestor::~foo~, etc.
handles /ancestor::foo or /preceding::foo where this is not the first step in the path, or ancestor::foo
handles /ancestor::* or /preceding::* where this is not the first step in the path, or ancestor::*, etc.
handles /@foo where this is not the first step in the path, or child::@foo
handles /~foo~ where this is not the first step in the path, or child::~foo~
handles /foo where this is not the first step in the path, or child::foo
handles /E<gt@foo>
handles /E<gt~foo~>
handles /E<gtfoo>
handles /.
handles /@foo
handles /ancestor::@foo or /preceding::@foo where this is the first step in the path
handles /ancestor::~foo~ or /preceding::~foo~ where this is the first step in the path
handles /ancestor::foo or /preceding::foo where this is the first step in the path
handles /ancestor::* or /preceding::* where this is the first step in the path
handles /~foo~
handles /foo
implementation of TPath::LogStream that simply prints to STDERR
interface of conditional expressions in predicates
implements logical conjunction of tests
any empty role used to tag boolean TPath::Tests
role of TPath::Tests that combine multiple other tests under some boolean operator
role for tests determining whether a node has some property
TPath::Test::Node implementing matching; e.g., //~foo~
TPath::Test::Node implementing matching; e.g., //~foo~
TPath::Test::Node implementing basic tag pattern; e.g., //foo
TPath::Test::Node implementing the wildcard; e.g., //*
implements logical negation of a test
implements logical disjunction of tests
implements logical function of tests which returns true iff only one test is true
applies type constraint on nodes
assorted type constraints