luaparser


Nameluaparser JSON
Version 3.3.0 PyPI version JSON
download
home_pagehttps://github.com/boolangery/py-lua-parser
SummaryA lua parser in Python
upload_time2024-10-27 11:29:23
maintainerNone
docs_urlNone
authorEliott Dumeix
requires_pythonNone
licenseMIT
keywords
VCS
bugtrack_url
requirements antlr4-python3-runtime multimethod
Travis-CI No Travis.
coveralls test coverage No coveralls.
            py-lua-parser
===============================================================================

.. image:: https://travis-ci.org/boolangery/py-lua-parser.svg?branch=master
    :target: https://travis-ci.org/boolangery/py-lua-parser
.. 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 grammar

Options
------------------------------------------------------------------------------

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 file


Quickstart
==============================================================================

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 item


You 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 astnodes

    tree = 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 astnodes

    src = "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)
    end


Command line
==============================================================================

Given:

.. code-block:: lua

    local function log(msg)
      print(msg)
    end

    log("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

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/boolangery/py-lua-parser",
    "name": "luaparser",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": null,
    "author": "Eliott Dumeix",
    "author_email": "eliott.dumeix@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/78/ee/3e3a26265dc7e3124c2ccef0bcf262dda2730f7bcf32b64ada99ed34f643/luaparser-3.3.0.tar.gz",
    "platform": null,
    "description": "py-lua-parser\n===============================================================================\n\n.. image:: https://travis-ci.org/boolangery/py-lua-parser.svg?branch=master\n    :target: https://travis-ci.org/boolangery/py-lua-parser\n.. image:: https://img.shields.io/pypi/v/luaparser.svg\n    :target: https://pypi.python.org/pypi/luaparser/\n.. image:: https://img.shields.io/pypi/pyversions/luaparser.svg\n    :target: https://pypi.python.org/pypi/luaparser/\n\nA Lua parser and AST builder written in Python.\n\nIt's both a development library and a command line tool.\n\n\nInstallation:\n------------------------------------------------------------------------------\n\nThe package can be installed through `pip`:\n\n.. code-block::\n\n    $ python3.6 -m pip install luaparser\n\nIt will install the shell command 'luaparser'.\n\n\nCompatibility with Lua grammar\n------------------------------------------------------------------------------\n\n3.2.1  =>  Lua 5.3 grammar\n3.2.1+ =>  Lua 5.4 grammar\n\nOptions\n------------------------------------------------------------------------------\n\nThese are the command-line flags:\n\nUsage: luaparser [options] filename\n\n.. code-block::\n\n    CLI Options:\n      --version                     Show program's version number and exit\n      -h, --help                    Show this help message and exit\n      -s, --source                  Source passed in a string\n      -x, --xml                     Set output format to xml\n      -o, --output                  Write output to file\n\n\nQuickstart\n==============================================================================\n\nNode structure\n------------------------------------------------------------------------------\n\nEach node contains the following data:\n\n.. code-block:: python\n\n\tclass Node:\n\t\t\"\"\"Base class for AST node.\"\"\"\n\t\tcomments: Comments\n\t\tfirst_token: Optional[Token]\n\t\tlast_token: Optional[Token]\n\t\tstart_char: Optional[int]\n\t\tstop_char: Optional[int]\n\t\tline: Optional[int]\n\n\nWorking on AST tree\n------------------------------------------------------------------------------\n\nMinimal exemple:\n\n.. code-block:: python\n\n    from luaparser import ast\n\n    src = \"\"\"\n        local function sayHello()\n          print('hello world !')\n        end\n        sayHello()\n        \"\"\"\n\n    tree = ast.parse(src)\n    print(ast.to_pretty_str(tree))\n\nwill display:\n\n.. code-block::\n\n    Chunk: {} 1 key\n      body: {} 1 key\n        Block: {} 1 key\n          body: [] 2 items\n            0: {} 1 key\n              LocalFunction: {} 3 keys\n                name: {} 1 key\n                  Name: {} 1 key\n                    id: \"sayHello\"\n                args: [] 0 item\n                body: [] 1 item\n                  0: {} 1 key\n                    Call: {} 2 keys\n                      func: {} 1 key\n                        Name: {} 1 key\n                          id: \"print\"\n                      args: [] 1 item\n                        0: {} 1 key\n                          String: {} 1 key\n                            s: \"hello world !\"\n            1: {} 1 key\n              Call: {} 2 keys\n                func: {} 1 key\n                  Name: {} 1 key\n                    id: \"sayHello\"\n                args: [] 0 item\n\n\nYou can run through the list of all the nodes in the tree using ast.walk(tree):\n\n.. code-block:: python\n\n    from luaparser import ast\n    from luaparser import astnodes\n\n    tree = ast.parse(\"local foo = 'bar'\")\n\n    for node in ast.walk(tree):\n        if isinstance(node, astnodes.Name):\n            process(node)\n\n\nAlternatively, you can use a node visitor:\n\n.. code-block:: python\n\n    from luaparser import ast\n    from luaparser import astnodes\n\n    src = \"local a = 42\"\n\n    class NumberVisitor(ast.ASTVisitor):\n        def visit_Number(self, node):\n            print('Number value = ' + str(node.n))\n\n    tree = ast.parse(src)\n    NumberVisitor().visit(tree)\n\n\nRendering lua code\n------------------------------------------------------------------------------\n\n.. warning:: Experimental feature\n\n.. code-block:: python\n\n    exp = Chunk(Block([\n        Forin(\n            targets=[Name('k'), Name('v')],\n            iter=[\n                Invoke(\n                    source=Name('bar'),\n                    func=Name('foo'),\n                    args=[Number(42)]\n                )\n            ],\n            body=Block([\n                Call(func=Name('print'), args=[Name('k'), Name('v')])\n            ]),\n\n        )\n    ]))\n\n    print(ast.to_lua_source(exp))\n\n\nWill render:\n\n.. code-block:: lua\n\n    for k, v in bar:foo(42) do\n        print(k, v)\n    end\n\n\nCommand line\n==============================================================================\n\nGiven:\n\n.. code-block:: lua\n\n    local function log(msg)\n      print(msg)\n    end\n\n    log(\"hello world !\")\n\n\n.. code-block:: bash\n\n    $ luaparser source.lua\n\n\nWill output:\n\n.. code-block:: json\n\n    {\n        \"Chunk\": {\n            \"body\": {\n                \"Block\": {\n                    \"body\": [\n                        {\n                            \"LocalFunction\": {\n                                \"name\": {\n                                    \"Name\": {\n                                        \"id\": \"log\"\n                                    }\n                                },\n                                \"args\": [\n                                    {\n                                        \"Name\": {\n                                            \"id\": \"msg\"\n                                        }\n                                    }\n                                ],\n                                \"body\": {\n                                    \"Block\": {\n                                        \"body\": [\n                                            {\n                                                \"Call\": {\n                                                    \"func\": {\n                                                        \"Name\": {\n                                                            \"id\": \"print\"\n                                                        }\n                                                    },\n                                                    \"args\": [\n                                                        {\n                                                            \"Name\": {\n                                                                \"id\": \"msg\"\n                                                            }\n                                                        }\n                                                    ]\n                                                }\n                                            }\n                                        ]\n                                    }\n                                }\n                            }\n                        },\n                        {\n                            \"Call\": {\n                                \"func\": {\n                                    \"Name\": {\n                                        \"id\": \"log\"\n                                    }\n                                },\n                                \"args\": [\n                                    {\n                                        \"String\": {\n                                            \"s\": \"hello world !\"\n                                        }\n                                    }\n                                ]\n                            }\n                        }\n                    ]\n                }\n            }\n        }\n    }\n\nCommand line\n==============================================================================\n\nDocumentation can be built with Sphinx:\n\n.. code-block::\n\n    $ cd doc\n    $ pip install -r requirements.txt\n    $ make html\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A lua parser in Python",
    "version": "3.3.0",
    "project_urls": {
        "Download": "https://github.com/boolangery/py-lua-parser/archive/3.3.0.tar.gz",
        "Homepage": "https://github.com/boolangery/py-lua-parser"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "fc02896cf9587a3ce6139a5277cea8679d27fb9b49e0acf26b9a2bdcd6099cac",
                "md5": "89c72fffc41d901391ad2a4b7b68ddba",
                "sha256": "d8cf3aa519a702d082a8492fb5d3ac65af88cc67066952ca23848d46e84dced6"
            },
            "downloads": -1,
            "filename": "luaparser-3.3.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "89c72fffc41d901391ad2a4b7b68ddba",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 58585,
            "upload_time": "2024-10-27T11:29:21",
            "upload_time_iso_8601": "2024-10-27T11:29:21.075776Z",
            "url": "https://files.pythonhosted.org/packages/fc/02/896cf9587a3ce6139a5277cea8679d27fb9b49e0acf26b9a2bdcd6099cac/luaparser-3.3.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "78ee3e3a26265dc7e3124c2ccef0bcf262dda2730f7bcf32b64ada99ed34f643",
                "md5": "1107553df6a2940d09676603e50f6b43",
                "sha256": "923f1c07fffbec6d7883e903b82f7f3b700a277b1948221018410f578df9bb8f"
            },
            "downloads": -1,
            "filename": "luaparser-3.3.0.tar.gz",
            "has_sig": false,
            "md5_digest": "1107553df6a2940d09676603e50f6b43",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 51911,
            "upload_time": "2024-10-27T11:29:23",
            "upload_time_iso_8601": "2024-10-27T11:29:23.051582Z",
            "url": "https://files.pythonhosted.org/packages/78/ee/3e3a26265dc7e3124c2ccef0bcf262dda2730f7bcf32b64ada99ed34f643/luaparser-3.3.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-27 11:29:23",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "boolangery",
    "github_project": "py-lua-parser",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [
        {
            "name": "antlr4-python3-runtime",
            "specs": [
                [
                    "==",
                    "4.13.2"
                ]
            ]
        },
        {
            "name": "multimethod",
            "specs": []
        }
    ],
    "lcname": "luaparser"
}
        
Elapsed time: 0.35294s