Skip to main content

Django application to detect cyclic imports

Project description

Django detect cyclic

Application to detect cyclic imports. With this application you can analyze the dependence of your applications

https://github.com/goinnn/django-detect-cyclic/raw/master/examples/example-only-cyclic-exclude.png

Requeriments

Installation

In your settings.py:

INSTALLED_APPS = (

    'django_detect_cyclic',

)

In your urls.py:

urlpatterns = patterns('',

    (r'^admin/detect_cyclic/', include('django_detect_cyclic.urls')),

)

Caption

  • The nodes are the applications, or the modules of the applications (if you use the option show-modules)

  • One edge means that the node source import the node destination

  • When there is a cycle the edge has a background color (the same color in all the cycle), and it label contains “Cycle X”

  • The label of the edges contains the weight in parentheses

  • If you use the options show-modules, each node has a background color. If two nodes are to the same application, they have the same background color.

  • If a edge is dotted, every import between these two nodes is into a function

Possibles Errors

It is possible that the next links are interested if you can some problem:

It is possible that you have to remove the pyc files:

find -iname "*.pyc" -exec rm "{}" \;

Usage

You have two ways, you can run a command:

python manage.py detect_cyclic
python manage.py detect_cyclic --include-apps="app1,app6,app7,app11" --file-name="my_graph.svg" --exclude-packages="migrations,templatetags" --verbosity=2
python manage.py detect_cyclic --include-apps="app1,app6" --show-modules --file-name="my_graph.svg" --exclude-packages="migrations" --verbosity=2
python manage.py detect_cyclic --include-apps="app1,app6" --only-cyclic --file-name="my_graph.svg" --exclude-packages="migrations" --verbosity=2

Or you can access via web to the wizard:

/admin/detect_cyclic/

Examples

To see more examples click in examples

Releases

0.0.5 (2012-07-12)

  • Change force-colors option to use-colors option

  • Change distribution of the wizard

  • Usability

0.0.4 (2012-07-12)

  • Wizard to create graphs (/admin/detect_cyclic/)

  • Format svg-js (beta)

  • Fix a little errors

0.0.3 (2012-07-10)

  • Add the option “scope-global”, this ignore the imports into the functions

  • Now if the verbosity option is 1, only show the errors

  • Now when a node (with show-modules) has the same name that a application, the node name will be app_name.__init__

  • Now the label of the cycle edges has the same color that the edge

  • Now disabled the colors of the edge and nodes when the format is not svg. But it is possible enabled if you use the “force color” option

  • Optimizations

  • New option “dotted-scope-local”. If the all import between two nodes are into a function the edge will be dotted

  • Fixed some little errors

0.0.2 (2012-07-09)

  • Documentation and examples

0.0.1 (2012-07-09)

  • Initial release.

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

django-detect-cyclic-0.0.5.tar.gz (76.7 kB view details)

Uploaded Source

File details

Details for the file django-detect-cyclic-0.0.5.tar.gz.

File metadata

File hashes

Hashes for django-detect-cyclic-0.0.5.tar.gz
Algorithm Hash digest
SHA256 47e4784957aade9d79af02aa0bc37a2650f9b776aacefb0b85a5b2eab9bc68ed
MD5 1936a973de58fd4e09afa6a9128bbae7
BLAKE2b-256 80af28e15f83abd399f54f6169c4b276ae20e8f4d8dabd0cfe886fc31be2de33

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