Skip to main content

No project description provided

Project description

ast-comments

An extension to the built-in ast module. Finds comments in source code and adds them to the parsed tree.

Installation

pip install ast-comments

Usage

There is no difference in usage between ast and ast-comments

>>> from ast_comments import *
>>> tree = parse("hello = 'hello' # comment to hello")

Parsed tree is an instance of the original ast.Module object. The only difference is that there is a new type of tree node: Comment

>>> tree
<_ast.Module object at 0x7ffba52322e0>
>>> tree.body
[<ast.Assign object at 0x10a01d5b0>, <ast_comments.Comment object at 0x10a09e0a0>]
>>> tree.body[1].value
'# comment to hello'
>>> dump(tree)
"Module(body=[Assign(targets=[Name(id='hello', ctx=Store())], value=Constant(value='hello')), Comment(value='# comment to hello', inline=True)], type_ignores=[])"

If you have python3.9 or above it's also possible to unparse the tree object with its comments preserved.

>>> print(unparse(tree))
hello = 'hello'  # comment to hello

Note: Python compile() cannot be run on the tree output from parse. The included pre_compile_fixer() function can be used to fix the tree (stripping comment nodes) if it will be necessary to compile the output.

More examples can be found in test_parse.py and test_unparse.py.

Contributing

You are welcome to open an issue or create a pull request

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

better_ast_comments-1.2.1.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

better_ast_comments-1.2.1-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file better_ast_comments-1.2.1.tar.gz.

File metadata

  • Download URL: better_ast_comments-1.2.1.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.2 CPython/3.11.6 Linux/6.0.19-4-MANJARO

File hashes

Hashes for better_ast_comments-1.2.1.tar.gz
Algorithm Hash digest
SHA256 97c0d174b062f06696b4ba63c3bb9782c95a71a02ad505f2cde54c9c7e391d8c
MD5 ca055283e092e4996b18ae29ef4d9adc
BLAKE2b-256 86cc6b5f687b2fe673f6ccda93d158d6f49552cb9fd44d87b8997f0b5cc9ea77

See more details on using hashes here.

File details

Details for the file better_ast_comments-1.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for better_ast_comments-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c4993af37ac2655f9997d3751a95bd8a14306d4de17d03d1a89e62d18bea9836
MD5 7b1f2e95e791de3c01d1a282430d8f69
BLAKE2b-256 5fa2226f4ba92a4661a5c5d9f8a98ef3fd3799aa6c35afd164c5e2db732dd19b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page