PHPackages                             niceforbear/sparser - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Parsing &amp; Serialization](/categories/parsing)
4. /
5. niceforbear/sparser

ActiveLibrary[Parsing &amp; Serialization](/categories/parsing)

niceforbear/sparser
===================

parser of string

v0.1.2(9y ago)017MITPHPPHP &gt;=5.6.0

Since Jun 19Pushed 9y ago1 watchersCompare

[ Source](https://github.com/niceforbear/sparser)[ Packagist](https://packagist.org/packages/niceforbear/sparser)[ Docs](https://github.com/niceforbear)[ RSS](/packages/niceforbear-sparser/feed)WikiDiscussions master Synced 2mo ago

READMEChangelogDependenciesVersions (4)Used By (0)

String Parser
=============

[](#string-parser)

Install
-------

[](#install)

Via Composer

```
$ composer require niceforbear/sparser
```

Usage
-----

[](#usage)

```
$context = new Context();
$user_in = "\$input equals '4' or \$input equals 'four'";
$reader = new StringReader($user_in);
$scanner = new Scanner($reader, $context);

while ($scanner->nextToken() != Scanner::EOF) {
    print $scanner->token();
    print "\t{$scanner->char_no()}";
    print "\t{$scanner->getTypeString()}\n";
}
```

```
$input = 'five';
$statement = "( \$input equals 'five')";

$engine = new MarkParse($statement);
$result = $engine->evaluate($input);
print "input: $input evaluating: $statement\n";
if($result){
    print "true!\n";
}else{
    print "false!\n";
}

```

Testing
-------

[](#testing)

Tests unavailable.

Contributing
------------

[](#contributing)

Please see [CONTRIBUTING](CONTRIBUTING.md) for details.

Credits
-------

[](#credits)

- [niceforbear](https://github.com/niceforbear)

License
-------

[](#license)

The MIT License (MIT). Please see [License File](LICENSE) for more information.

About EBNF
----------

[](#about-ebnf)

- expr ::= operand (orExpr | andExpr) \*
- operand ::= ( '(' expr ')' | | variable ) (eqExpr) \*
- orExpr ::= 'or' operand
- andExpr ::= 'and' operand
- eqExpr ::= 'equals' operand
- variable ::= '$'

###  Health Score

23

—

LowBetter than 27% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity6

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity50

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

3

Last Release

3617d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/bc213e9d964d9ba32f547f2ded23887b5c6ea746e42158b9d24cb1c52f576f8c?d=identicon)[niceforbear](/maintainers/niceforbear)

---

Top Contributors

[![niceforbear](https://avatars.githubusercontent.com/u/3595599?v=4)](https://github.com/niceforbear "niceforbear (1 commits)")

---

Tags

stringparsertoolbasic

### Embed Badge

![Health badge](/badges/niceforbear-sparser/health.svg)

```
[![Health](https://phpackages.com/badges/niceforbear-sparser/health.svg)](https://phpackages.com/packages/niceforbear-sparser)
```

###  Alternatives

[nikic/php-parser

A PHP parser written in PHP

17.4k902.6M1.8k](/packages/nikic-php-parser)[doctrine/lexer

PHP Doctrine Lexer parser library that can be used in Top-Down, Recursive Descent Parsers.

11.2k910.8M118](/packages/doctrine-lexer)[erusev/parsedown

Parser for Markdown.

15.0k151.8M732](/packages/erusev-parsedown)[league/commonmark

Highly-extensible PHP Markdown parser which fully supports the CommonMark spec and GitHub-Flavored Markdown (GFM)

2.9k404.0M702](/packages/league-commonmark)[masterminds/html5

An HTML5 parser and serializer.

1.8k242.8M229](/packages/masterminds-html5)[sabberworm/php-css-parser

Parser for CSS Files written in PHP

1.8k191.2M65](/packages/sabberworm-php-css-parser)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
