Skip to content
forked from jrfonseca/xdot.py

Interactive viewer for graphs written in Graphviz's dot language.

Notifications You must be signed in to change notification settings

dwillmer/xdot.py

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

About xdot.py

xdot.py is an interactive viewer for graphs written in Graphviz's dot language.

It uses internally the graphviz's xdot output format as an intermediate format, and PyGTK and Cairo for rendering.

xdot.py can be used either as a standalone application from command line, or as a library embedded in your python application.

Status

xdot.py script became much more popular than I ever anticipated, and it there is potential for further enhancements. However xdot.py already meets my own needs as it is now, and unfortunately I don't have much time for maintain it myself.

If this version of xdot.py does not meet your needs then take a look at the outstanding issues or the comments below, for patches and links for other forks. xdot.py is small and self contained, so feel free to include it in your own projects.

Features

  • Since it doesn't use bitmaps it is fast and has a small memory footprint.
  • Arbitrary zoom.
  • Keyboard/mouse navigation.
  • Supports events on the nodes with URLs.
  • Animated jumping between nodes.
  • Highlights node/edge under mouse.

Changelog

  • 2013-05-12: Text based node search (by Salva and ludw1g.m3i3r, issue 68)

  • 2012-11-24: Printing support (by ludw1g.m3i3r, issue 74)

  • 2011-09-01: Fix forward slash escaping (issue 61)

  • 2011-02-13: Show dotted lines in xdot (by djs52uk, issue 50)

  • 2010-12-12: Support images (thanks to Alberto Rodríguez)

  • 2010-01-32: Add Quit key binding (from sk, issue #30)

  • 2009-09-30: Add a reload button (fixes issue #22)

  • 2009-09-30: Properly handle motion-notify-event (from lodatom, issue #24)

  • 2009-09-20: Automatically reloads open file when it changes (from Robert Meerman, issue #21)

  • 2009-09-20: Add support for ColorBrewer Color Schemes(from to michael.hliao, issue #23).

  • 2009-08-09: Upload to PyPi(thanks to Marius Gedminas, issue #19)

  • 2009-05-24: Reloads the file on the 'r' key (from peterbjorgensen).

  • 2009-04-09: Render subgraphs correctly.

  • 2009-03-04: Support filled bezier shapes.

  • 2009-01-29: Check for unicode input; check subprocess returncode (from Jaap Karssenberg).

  • 2008-10-27: Replace pydot and pyparsing by a much faster hand written lexer and parser (issue #9).

  • 2008-09-02: Make mouse wheel zoom around the mouse cursor rather than center of window (from Marius Gedminas).

  • 2008-09-02: Handle polylines. Handle ports in node names.

  • 2008-07-27: Allow to specify the graphviz filter to use.

  • 2008-07-13: Commit several enhancements done by Marius Gedminas, such as, animated jumping between nodes, highlighted node/edge under mouse, and support to more xdot language features.

Known Issues

  • Not all xdot attributes are supported or correctly rendered yet. It works well for my applications but YMMV.

  • Text doesn't scale properly to large sizes if font hinting is enabled. I haven't find a reliable way to disable font hinting during rendering yet.

See also the googlecode issue tracker.

Screenshots

Profile 1 Screenshot Profile 2 Screenshot Control Flow Graph

Requirements

Windows users

Download and install:

Debian/Ubuntu users

Run:

apt-get install python-gtk2 graphviz

Usage

Command Line

Usage: 
	xdot.py [file]

Options:
  -h, --help            show this help message and exit
  -f FILTER, --filter=FILTER
                        graphviz filter: dot, neato, twopi, circo, or fdp
                        [default: dot]
  -n, --no-filter       assume input is already filtered into xdot format (use
                        e.g. dot -Txdot)

Shortcuts:
  Up, Down, Left, Right     scroll
  PageUp, +, =              zoom in
  PageDown, -               zoom out
  R                         reload dot file
  F                         find
  Q                         quit
  P                         print
  Escape                    halt animation
  Ctrl-drag                 zoom in/out
  Shift-drag                zooms an area

If no input file is given then it will read the dot graph from the standard input.

Embedding

See included example.py script for an example of how to embedded xdot.py into another application.

Screenshot

Download

Links

About

Interactive viewer for graphs written in Graphviz's dot language.

Resources

Stars

Watchers

Forks

Packages

No packages published