Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bwohlberg/jonga

Jonga: Python function call graph visualization
https://github.com/bwohlberg/jonga

call-graph call-graph-analysis code-visualization dependency-graph documentation-tool

Last synced: 6 days ago
JSON representation

Jonga: Python function call graph visualization

Awesome Lists containing this project

README

        

[![Documentation Status](https://readthedocs.org/projects/jonga/badge/?version=latest)](http://jonga.readthedocs.io/en/latest/?badge=latest)
[![PyPi Release](https://badge.fury.io/py/jonga.svg)](https://badge.fury.io/py/jonga)
[![PyPi Downloads](https://static.pepy.tech/personalized-badge/jonga?period=total&left_color=grey&right_color=brightgreen&left_text=downloads)](https://pepy.tech/project/jonga)
[![Conda Forge Release](https://img.shields.io/conda/vn/conda-forge/jonga.svg)](https://anaconda.org/conda-forge/jonga)
[![Conda Forge Downloads](https://img.shields.io/conda/dn/conda-forge/jonga.svg)](https://anaconda.org/conda-forge/jonga)
[![Supported Python Versions](https://img.shields.io/badge/python-3.3+-green.svg)](https://github.com/bwohlberg/jonga)
[![Package License](https://img.shields.io/pypi/l/jonga.svg)](https://github.com/bwohlberg/jonga)
[![Binder](http://mybinder.org/badge.svg)](https://mybinder.org/v2/gh/bwohlberg/jonga/master?filepath=examples/index.ipynb)

# Jonga

Jonga is a Python package that generates a directed graph representing
function calls within a block of Python code, intended for inclusion in
Sphinx package documentation. There are a number of alternative packages
with similar goals, including

- [pycallgraph](https://github.com/gak/pycallgraph)
- [pyan](https://github.com/davidfraser/pyan)
- [snakefood](https://github.com/blais/snakefood)

but none of them is entirely suitable for generating function/method
call vizualizations for inclusion within package documentation. In
particular, none of these other packages correctly identifies method
classes within a hierarchy of derived classes.

## Requirements

The primary requirement is Python 3.3 or greater (this packages is *not*
compatible with Python 2), imposed by the use of the `__qualname__`
function attribute and
[inspect.getclosurevars](https://docs.python.org/3/library/inspect.html#inspect.getclosurevars).
The `__qualname__` attribute could be replaced in earlier versions of
Python by [qualname](https://github.com/wbolster/qualname), but there is
no obvious replacement for
[inspect.getclosurevars](https://docs.python.org/3/library/inspect.html#inspect.getclosurevars),
which was introduced in Python 3.3.

The other major requirement is
[pygraphviz](https://pygraphviz.github.io/).

### Optional

Package [matplotlib](http://matplotlib.org) is required to run the
included [Jupyter Notebook](http://jupyter.org/) examples.

Package [pytest](https://github.com/pytest-dev/pytest) is
required to run the tests (`pytest` in the repository root directory).

Packages [sphinx](http://www.sphinx-doc.org/en/stable),
[sphinx-bootstrap-theme](http://ryan-roemer.github.io/sphinx-bootstrap-theme/README.html),
and [numpydoc](https://github.com/numpy/numpydoc) are required to build
the documentation (`make html` in the `docs` directory).

## Usage

Scripts illustrating usage of the package can be found in the `examples`
directory of the source distribution. These examples can be run from the
root directory of the package by, for example

python examples/example1.py

To run these scripts prior to installing the package it will be
necessary to first set the `PYTHONPATH` environment variable to include
the root directory of the package. For example, in a `bash` shell

export PYTHONPATH=$PYTHONPATH:`pwd`

from the root directory of the package.

[Jupyter Notebook](http://jupyter.org/) versions of the example scripts
are also included in the `examples` directory, and can be viewed online
via
[nbviewer](http://nbviewer.jupyter.org/github/bwohlberg/jonga/blob/master/examples/index.ipynb),
or run interactively at
[binder](https://mybinder.org/v2/gh/bwohlberg/jonga/master?filepath=examples/index.ipynb).

## Documentation

Documentation is available online at [Read the
Docs](http://jonga.rtfd.io/), or can be built from the `docs` directory of
the source distribution by the command

make html

in which case the HTML documentation can be found in the
`build/sphinx/html` directory (the top-level document is `index.html`).

## Contact

Please submit bug reports, comments, etc. via the [GitHub Issues
interface](https://github.com/bwohlberg/jonga/issues).

## License

This package is made available under the terms of the GNU General Public
License as published by the Free Software Foundation; either version 2
of the License (see the included `LICENSE` file), or (at your option)
any later version.