Enhance IXpathContext behavior

Description

Enable the removal of defined variables. Variable definitions should exist within well defined scopes. All but a 'global' scope must be able to remove variables no longer in scope.

Enable the use of relative xpath values during evaluation. Requiring full paths makes transform reuse more difficult, and "//..." is too likely to be ambiguous. It should be possible to make xpath evaluations relative to a specific root node. Refer to https://stackoverflow.com/questions/33416524/libxml2-xpath-relative-to-sub-node for illustration of how switch the logical root. Refer to https://stackoverflow.com/questions/19474376/node-selection-using-xpath-in-libxml2 for evaluation to a node.

Enable iteration of a multiple node evaluation. The use of for-each (or other looping construct) suggests a need to select multiple nodes and act on each one.

Conclusion

None

Activity

Show:

Gavin Halliday May 6, 2020 at 1:44 PM

Anthony Fishbeck May 5, 2020 at 2:37 AM

Included script engine and xpath functions.

  1. XPath functions for checking authorization

  2. EXSLT xpath funcitons

  3. Script parameters and variables

  4. Scopes for variables.

  5. Saving working cursor (xpathContext locations)

  6. "for-each" operation.

  7. relative path support (never worked prior)

  8. "choose" with multiple "when" clauses.

  9. "if" conditional

  10. "assert" and "fail" operations.

  11. Arbitrary namespace prefixes.

  12. add-value (like ptree addProp)

  13. Consistent operation names: AppendValue is now "append-to-value"
    and SetValue is now "set-value".

  14. built target strings (use script level xpath to build target xpath)

  15. unit tests

Fixed
Pinned fields
Click on the next to a field label to start pinning.

Details

Components

Assignee

Reporter

Priority

Compatibility

Minor

Fix versions

Roadmap

Not applicable

Created April 29, 2019 at 7:10 PM
Updated May 6, 2020 at 1:44 PM
Resolved May 5, 2020 at 9:25 AM