Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/boolangery/py-lua-parser
A Lua parser and AST builder written in Python.
https://github.com/boolangery/py-lua-parser
ast lua parser python
Last synced: 5 days ago
JSON representation
A Lua parser and AST builder written in Python.
- Host: GitHub
- URL: https://github.com/boolangery/py-lua-parser
- Owner: boolangery
- License: mit
- Created: 2017-11-05T18:16:35.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-27T11:33:34.000Z (2 months ago)
- Last Synced: 2024-12-28T11:04:06.609Z (12 days ago)
- Topics: ast, lua, parser, python
- Language: Python
- Homepage:
- Size: 732 KB
- Stars: 127
- Watchers: 7
- Forks: 40
- Open Issues: 4
-
Metadata Files:
- Readme: README.rst
- License: LICENSE.txt
Awesome Lists containing this project
README
py-lua-parser
===============================================================================.. image:: https://github.com/boolangery/py-lua-parser/actions/workflows/python-package.yml/badge.svg
:target: https://github.com/boolangery/py-lua-parser/actions/workflows/python-package.yml
.. image:: https://img.shields.io/pypi/v/luaparser.svg
:target: https://pypi.python.org/pypi/luaparser/
.. image:: https://img.shields.io/pypi/pyversions/luaparser.svg
:target: https://pypi.python.org/pypi/luaparser/A Lua parser and AST builder written in Python.
It's both a development library and a command line tool.
Installation:
------------------------------------------------------------------------------The package can be installed through `pip`:
.. code-block::
$ python3.6 -m pip install luaparser
It will install the shell command 'luaparser'.
Compatibility with Lua grammar
------------------------------------------------------------------------------3.2.1 => Lua 5.3 grammar
3.2.1+ => Lua 5.4 grammarOptions
------------------------------------------------------------------------------These are the command-line flags:
Usage: luaparser [options] filename
.. code-block::
CLI Options:
--version Show program's version number and exit
-h, --help Show this help message and exit
-s, --source Source passed in a string
-x, --xml Set output format to xml
-o, --output Write output to fileQuickstart
==============================================================================Node structure
------------------------------------------------------------------------------Each node contains the following data:
.. code-block:: python
class Node:
"""Base class for AST node."""
comments: Comments
first_token: Optional[Token]
last_token: Optional[Token]
start_char: Optional[int]
stop_char: Optional[int]
line: Optional[int]Working on AST tree
------------------------------------------------------------------------------Minimal exemple:
.. code-block:: python
from luaparser import ast
src = """
local function sayHello()
print('hello world !')
end
sayHello()
"""tree = ast.parse(src)
print(ast.to_pretty_str(tree))will display:
.. code-block::
Chunk: {} 1 key
body: {} 1 key
Block: {} 1 key
body: [] 2 items
0: {} 1 key
LocalFunction: {} 3 keys
name: {} 1 key
Name: {} 1 key
id: "sayHello"
args: [] 0 item
body: [] 1 item
0: {} 1 key
Call: {} 2 keys
func: {} 1 key
Name: {} 1 key
id: "print"
args: [] 1 item
0: {} 1 key
String: {} 1 key
s: "hello world !"
1: {} 1 key
Call: {} 2 keys
func: {} 1 key
Name: {} 1 key
id: "sayHello"
args: [] 0 itemYou can run through the list of all the nodes in the tree using ast.walk(tree):
.. code-block:: python
from luaparser import ast
from luaparser import astnodestree = ast.parse("local foo = 'bar'")
for node in ast.walk(tree):
if isinstance(node, astnodes.Name):
process(node)Alternatively, you can use a node visitor:
.. code-block:: python
from luaparser import ast
from luaparser import astnodessrc = "local a = 42"
class NumberVisitor(ast.ASTVisitor):
def visit_Number(self, node):
print('Number value = ' + str(node.n))tree = ast.parse(src)
NumberVisitor().visit(tree)Rendering lua code
------------------------------------------------------------------------------.. warning:: Experimental feature
.. code-block:: python
exp = Chunk(Block([
Forin(
targets=[Name('k'), Name('v')],
iter=[
Invoke(
source=Name('bar'),
func=Name('foo'),
args=[Number(42)]
)
],
body=Block([
Call(func=Name('print'), args=[Name('k'), Name('v')])
]),)
]))print(ast.to_lua_source(exp))
Will render:
.. code-block:: lua
for k, v in bar:foo(42) do
print(k, v)
endCommand line
==============================================================================Given:
.. code-block:: lua
local function log(msg)
print(msg)
endlog("hello world !")
.. code-block:: bash
$ luaparser source.lua
Will output:
.. code-block:: json
{
"Chunk": {
"body": {
"Block": {
"body": [
{
"LocalFunction": {
"name": {
"Name": {
"id": "log"
}
},
"args": [
{
"Name": {
"id": "msg"
}
}
],
"body": {
"Block": {
"body": [
{
"Call": {
"func": {
"Name": {
"id": "print"
}
},
"args": [
{
"Name": {
"id": "msg"
}
}
]
}
}
]
}
}
}
},
{
"Call": {
"func": {
"Name": {
"id": "log"
}
},
"args": [
{
"String": {
"s": "hello world !"
}
}
]
}
}
]
}
}
}
}Command line
==============================================================================Documentation can be built with Sphinx:
.. code-block::
$ cd doc
$ pip install -r requirements.txt
$ make html