NAME

Map::Tube::GraphViz - GraphViz output for Map::Tube.

SYNOPSIS

use Map::Tube::GraphViz;
my $obj = Map::Tube::GraphViz->new(%params);
$obj->graph($output_file);

METHODS

new(%params)
Constructor.
  • callback_edge

    Edge callback.
    Default value is this:
    sub { 
            my ($self, $from, $to) = @_;
            $self->{'_g'}->add_edge(
            	'from' => $from,
            	'to' => $to,
            );
            return;
    }
  • callback_node

    Node callback.
    Default value is \&Map::Tube::GraphViz::Utils::node_color.
  • driver

    GraphViz2 driver.
    Default value is 'dot'.
  • output

    GraphViz2 output.
    It is required.
    Default value is 'png'.
    Possible values are 'png' and 'text'.
  • tube

    Map::Tube object.
    It is required.
    Default value is undef.
graph($output_file)
Get graph and save it to $output_file file.
Returns undef.

ERRORS

new():
        Parameter 'tube' is required.
        Parameter 'tube' must be 'Map::Tube' object.
        Parameter 'output' is required.
        Unsupported 'output' parameter '%s'.
        From Map::Tube::GraphViz::Utils::color_line():
                No color for line '%s'.
        From Class::Utils::set_params():
                Unknown parameter '%s'.

EXAMPLE1

# Pragmas.
use strict;
use warnings;

# Modules.
use English;
use Error::Pure qw(err);
use Map::Tube::GraphViz;

# Arguments.
if (@ARGV < 1) {
        print STDERR "Usage: $0 metro\n";
        exit 1;
}
my $metro = $ARGV[0];

# Object.
my $class = 'Map::Tube::'.$metro;
eval "require $class;";
if ($EVAL_ERROR) {
        err "Cannot load '$class' class.",
                'Error', $EVAL_ERROR;
}

# Metro object.
my $tube = eval "$class->new";
if ($EVAL_ERROR) {
        err "Cannot create object for '$class' class.",
                'Error', $EVAL_ERROR;
}

# GraphViz object.
my $g = Map::Tube::GraphViz->new(
        'driver' => 'neato',
        'tube' => $tube,
);

# Get graph to file.
$g->graph($metro.'.png');

# Print file.
system "ls -l $metro.png";

# Output without arguments like:
# Usage: /tmp/SZXfa2g154 metro

# Output with 'Berlin' argument like:
# -rw-r--r-- 1 skim skim 1503518 Dec 17 01:10 Berlin.png

EXAMPLE2

# Pragmas.
use strict;
use warnings;

# Modules.
use English;
use Error::Pure qw(err);
use Map::Tube::GraphViz;
use Map::Tube::GraphViz::Utils qw(node_color_without_label);

# Arguments.
if (@ARGV < 1) {
        print STDERR "Usage: $0 metro\n";
        exit 1;
}
my $metro = $ARGV[0];

# Object.
my $class = 'Map::Tube::'.$metro;
eval "require $class;";
if ($EVAL_ERROR) {
        err "Cannot load '$class' class.",
                'Error', $EVAL_ERROR;
}

# Metro object.
my $tube = eval "$class->new";
if ($EVAL_ERROR) {
        err "Cannot create object for '$class' class.",
                'Error', $EVAL_ERROR;
}

# GraphViz object.
my $g = Map::Tube::GraphViz->new(
        'callback_node' => \&node_color_without_label,
        'driver' => 'neato',
        'tube' => $tube,
);

# Get graph to file.
$g->graph($metro.'.png');

# Print file.
system "ls -l $metro.png";

# Output without arguments like:
# Usage: /tmp/SZXfa2g154 metro

# Output with 'Berlin' argument like:
# -rw-r--r-- 1 skim skim 1503518 Dec 17 01:10 Berlin.png

DEPENDENCIES

Class::Utils, Error::Pure, GraphViz2, List::MoreUtils, Map::Tube::GraphViz::Utils, Readonly, Scalar::Util.

SEE ALSO

Map::Tube.

REPOSITORY

https://github.com/tupinek/Map-Tube-GraphViz

AUTHOR

Michal Špaček mailto:skim@cpan.org

http://skim.cz

LICENSE AND COPYRIGHT

© 2014 Michal Špaček
Artistic License
BSD 2-Clause License

VERSION

0.01