php-parser

js
Parse PHP code from JS and returns its AST
Version 3.2.3 License BSD-3-Clause
Keywords
phpphp5php7php8parserlexertokenizerast
INSTALL
Type:
Version:
- Static
- Latest Patch
- Latest Minor
- Latest Major
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.5
- 3.1.4
- 3.1.3
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.2.0
- 2.1.0
- 2.0.7
- 2.0.6
- 2.0.5
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.1.5
- 0.1.4
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- 0.0.10
- 0.0.9
- 0.0.8
- 0.0.7
- 0.0.6
- 0.0.5
- 0.0.4
- 0.0.3
- 0.0.2
- 0.0.1
- 3.1.0-beta.11
- 3.1.0-beta.10
- 3.1.0-beta.9
- 3.1.0-beta.8
- 3.1.0-beta.7
- 3.1.0-beta.6
- 3.1.0-beta.5
- 3.1.0-beta.4
- 3.1.0-beta.3
- 3.1.0-beta.2
- 3.1.0-beta.1
- 3.1.0-beta.0
- 3.0.0-prerelease.9
- 3.0.0-prerelease.8
- 3.0.0-prerelease.7
- 3.0.0-prerelease.6
- 3.0.0-prerelease.5
- 3.0.0-prerelease.4
- 3.0.0-prerelease.3
- 3.0.0-prerelease.2
- 3.0.0-prerelease.1
- 3.0.0-alpha2
- 3.0.0-alpha1
- 3.0.0-alpha.3
- 2.0.0-pre8
- 2.0.0-pre7
- 2.0.0-pre6
- 2.0.0-pre5
- 2.0.0-pre4
- 2.0.0-pre2
- 2.0.0-pre1
- 2.0.0-alpha.2
- 2.0.0-alpha.1
php-parser
This JavaScript library parses PHP code and converts it to an AST.
Installation
This library is distributed with npm :
npm install php-parser --save
Usage
// initialize the php parser factory class
const fs = require("fs");
const path = require("path");
const engine = require("php-parser");
// initialize a new parser instance
const parser = new engine({
// some options :
parser: {
extractDoc: true,
php7: true,
},
ast: {
withPositions: true,
},
});
// Retrieve the AST from the specified source
const eval = parser.parseEval('echo "Hello World";');
// Retrieve an array of tokens (same as php function token_get_all)
const tokens = parser.tokenGetAll('<?php echo "Hello World";');
// Load a static file (Note: this file should exist on your computer)
const phpFile = fs.readFileSync("./example.php");
// Log out results
console.log("Eval parse:", eval);
console.log("Tokens parse:", tokens);
console.log("File parse:", parser.parseCode(phpFile));
Sample AST output
{
'kind': 'program',
'children': [
{
'kind': 'echo',
'arguments': [
{
'kind': 'string',
'isDoubleQuote': true,
'value': 'Hello World'
}
]
}
]
}
- Try it online (demo) : http://glayzzle.com/php-parser/
- Or from AST Explorer : https://astexplorer.net/
API Overview
The main API exposes a class with the following methods :
- parseEval(String|Buffer) : parse a PHP code in eval style mode (without php open tags)
- parseCode(String|Buffer, String filename) : parse a PHP code by using php open tags.
- tokenGetAll(String|Buffer) : retrieves a list of all tokens from the specified input.
You can also pass options that change the behavior of the parser/lexer.
Documentation
Related projects
- prettier/plugin-php : Prettier PHP Plugin
- babel-preset-php : Babel preset for converting PHP syntax to JavaScript. It can run subset of PHP in the browser or in Node.js
- wp-pot : Generate pot file for WordPress plugins and themes
- crane : PHP Intellisense/code-completion for VS Code
- php-unparser : Produce code that uses the style format recommended by PSR-1 and PSR-2.
- php-writer : Update PHP scripts from their AST
- ts-php-inspections : Provide PHP code inspections written in typescript
- php-reflection : Reflection API for PHP files
- vscode-phpunit : vscode phpunit extension
- lua2php : a Lua to PHP transpiler
You can add here your own project by opening an issue request.
License
This library is released under BSD-3 license clause.