lyquidity/xpath2

Provides XPath 2.0 statement execution library for PHP

dev-develop 2023-01-11 01:07 UTC

This package is auto-updated.

Last update: 2025-01-11 05:50:44 UTC


README

Table of contents

About the project

PHP does include an XPath 1.0 implementation but at the time of writing does not include processor to handle XPath 2.0 expressions. XPath queries are expected run against XML documents and are expected to respect the types implied by XML documents and the query. Although PHP has only a limited type system (string, integer, double/float, array) the XPath process respects all XML types an will coerce values of one type to another.

This library implements the XPath 2.0 specification for PHP and is able to pass the 15,000 or so XPath 2.0 conformance suite tests.

Note that this project does NOT implement an XSLT 2.0 processor or an XQuery statement evaluator.

Status

XPath 2.0 conformance

The conformance suite used is XQTS 1.0.3 2010-09-17. Not all the tests defined by the suite are used because many test XQueries. Instead the tests used are the ones in the test case documents that declare an attribute @is-XPath2 with a value of 'true'. There are about 9,000 such tests.

Statistics

This project comprises 53972 lines in 191 files

Motivation

This project is standalone but is also part of the XBRL project.

XBRL Formulas make extensive use of XPath 2.0 both to compute components of formula definitions and to define how aspects of the various formula specifications should be interpreted and turned into executable code.

Dependencies

This project depends on pear/log and lyquidity/xml

License

This project is released under GPL version 3.0

What does this mean?

It means you can use the source code in any way you see fit. However, the source code for any changes you make must be made available to others and must be made available on the same terms as you receive the source code in this project: under a GPL v3.0 license. You must include the license of this project with any distribution of the source code whether the distribution includes all the source code or just part of it. For example, if you create a class that derives from one of the classes provided by this project - a new taxonomy class, perhaps - that is derivative.

What does this not mean?

It does not mean that any products you create that only use this source code must be released under GPL v3.0. If you create a budgeting application that uses the source code from this project to access data in instance documents, used by the budgeting application to transfer data, that is not derivative.

Contributing

We welcome contributions. See our contributions page for more information. If you do choose to contribute we will ask you to agree to our Contributor License Agreement (CLA). We will ask you to agree to the terms in the CLA to assure other users that the code they use is not going to be encumbered by a labyrinth of different license and patent liabilities. You are also urged to review our code of conduct.

Install

The project can be installed by composer. Assuming Composer is installed and a shortcut to the program is called 'composer' then the command to install this project is:

composer require lyquidity/xpath2:dev-master lyquidity/utilities:dev-master lyquidity/xml:dev-master --prefer-dist

Or fork or download the repository. It will also be necessary to download and install the XML, utilities and pear/Log projects.

Getting started

The examples folder includes illustrations of using the library to execute XPath 2.0 queries against XML documents.

Assuming you have installed the library using composer then this PHP application will run the test:

<php
require_once __DIR__ . '/vendor/autoload.php';
include __DIR__ . "/vendor/lyquidity/XPath2/examples/examples.php";