wreed4 bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
..
brain bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
COPYING bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
COPYING.LESSER bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
README bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
README.Python3 bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
__init__.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
__pkginfo__.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
as_string.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
bases.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
builder.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
exceptions.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
inference.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
inspector.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
manager.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
mixins.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
node_classes.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
nodes.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
protocols.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
raw_building.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
rebuilder.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
scoped_nodes.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ
utils.py bdc79f8f25 Added .vim/ folder to repo 11 gadi atpakaļ

README

ASTNG
=====

What's this ?
-------------

The aim of this module is to provide a common base representation of
python source code for projects such as pychecker, pyreverse,
pylint... Well, actually the development of this library is essentially
governed by pylint's needs.

It provides a compatible representation which comes from the `_ast` module.
It rebuilds the tree generated by the builtin _ast module by recursively
walking down the AST and building an extended ast (let's call it astng ;). The
new node classes have additional methods and attributes for different usages.
They include some support for static inference and local name scopes.
Furthermore, astng builds partial trees by inspecting living objects.

Main modules are:

* `bases`, `node_classses` and `scoped_nodes` contain the classes for the
different type of nodes of the tree.

* the `manager` contains a high level object to get astng trees from
source files and living objects. It maintains a cache of previously
constructed tree for quick access


Installation
------------

Extract the tarball, jump into the created directory and run ::

python setup.py install

For installation options, see ::

python setup.py install --help


If you have any questions, please mail the
python-project@lists.logilab.org mailing list for support. See
http://lists.logilab.org/mailman/listinfo/python-projects for
subscription information and archives.

Test
----

Tests are in the 'test' subdirectory. To launch the whole tests suite
at once, you may use the 'pytest' utility from logilab-common (simply
type 'pytest' from within this directory) or if you're running python
>= 2.7, using discover, for instance::

python -m unittest discover -p "unittest*.py"