ckr / fiql-parser
Library to parse a FIQL string into an abstract syntax tree
Installs: 64
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/ckr/fiql-parser
Requires
- php: >=5.4
Requires (Dev)
- phpspec/phpspec: ~2.1
This package is not auto-updated.
Last update: 2025-10-25 23:42:38 UTC
README
This library provides a parser for the Feed Item Query Language. The parser creates a syntax tree from a string expression in the Feed Item Query Language (http://tools.ietf.org/html/draft-nottingham-atompub-fiql-00)
Note that this library is not yet stable enough for production usage. If you find a bug, please help by creating an issue on github.
Requirements
This library currently does not use any third party dependencies. A PHP version >= 5.4 is required. For testing, phpspec is used.
Basic Usage
// autoloading is psr-4 compliant, so we can use composer require 'vendor/autoload.php'; // initialize scanner and parser $scanner = new \Ckr\Fiql\Scanner(); $parser = new \Ckr\Fiql\Parser($scanner); // parse expression to a syntax tree $syntaxTree = $parser->parse('field==value,second=lt=val;requiredField'); // example visitor usage $visitor = new \Ckr\Fiql\Visitor\Printer(); $visitor->visit($syntaxTree); echo 'The syntax tree visualized:' . PHP_EOL; echo $visitor->getText(); echo PHP_EOL;
Syntax Tree
The syntax tree is composed of nodes implementing \Ckr\Fiql\Tree\Node.
Visitor
You can implement a custom visitor class (implementing \Ckr\Fiql\Tree\Visitor) to process
the syntax tree for your purposes, e.g. to check for matching feeds items. This library
provides only one visitor, \Ckr\Fiql\Visitor\Printer, which is mainly used to
visualize and compare syntax trees.
References
- FIQL definition: http://tools.ietf.org/html/draft-nottingham-atompub-fiql-00
- FIQL parser python: https://github.com/sergedomk/fiql_parser