8 breaking releases

0.9.0 Dec 13, 2023
0.8.0 Feb 22, 2023
0.7.0 Jun 30, 2022
0.6.0 Feb 24, 2022
0.2.0 Jun 4, 2021

#1193 in Parser implementations

Download history 32/week @ 2024-02-23 16/week @ 2024-03-01 1/week @ 2024-03-08 16/week @ 2024-03-15 24/week @ 2024-03-22 30/week @ 2024-03-29

70 downloads per month

Apache-2.0

1MB
19K SLoC

χrust

XPath, XQuery, and XSLT for Rust

Pronounced "crust".

The goal of this project is to implement XPath 3.1, XQuery 3.1 and XSLT 3.0 in Rust. Also included is an XML parser, using a parser combinator inspired by Nom.

Currently the project is a proof-of-concept. There is a rudimentary implementation of the XQuery and XPath Data Model 3.1, along with an implementation of XPath which, roughly speaking, conforms to version 1.0 (with a few other features, such as FLWR expressions). The XSLT implementation can evaluate basic XSL stylesheets, but is still incomplete wrt the XSLT v1.0 specification.

Design

The library separates parsing from evaluation. The XPath and XSLT are parsed (or "compiled") into an internal representation, a "transformation", which is then evaluated.

This means it won't matter how an expression is written; it will be compiled into the same internal form. For example, the XPath expression:

if $a then "a is true" else ""

will result in the same internal format as:

<xsl:if test="$a">
  a is true
</xsl:if>

This approach means that the XPath and XSLT modules are simply mappings from their respective syntaxes to an χrust transformation.

The Plan

  1. Complete the XPath 1.0 implementation.
  2. Implement all XSLT v1.0 functionality.
  3. Improve XDM, XPath; achieve v2.0-v3.1 compliance.
  4. Introduce all v3.0 features to the XSLT engine.

NB. We're picking the low-hanging fruit first. So major, fundamental features of the languages are being implemented to begin with. The fine detail will be added later. So although we're aiming for v1.0 functionality as a baseline, the eventual desire to implement all of v3.0 dictates that some more advanced features will be implemented sooner rather than later.

Documentation

See the XSLT module for an example of how to evaluate an XSL stylesheet.

Examples

Compliance

Status of docs/compliance.md with XDM, XPath, XQuery, and XSLT.

Dependencies

~5.5–7.5MB
~157K SLoC