GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  GRAPH::EASY::PARSER::GRAPHVIZ (3)

.ds Aq ’

NAME

Graph::Easy::Parser::Graphviz - Parse Graphviz text into Graph::Easy

CONTENTS

SYNOPSIS



        # creating a graph from a textual description

        use Graph::Easy::Parser::Graphviz;
        my $parser = Graph::Easy::Parser::Graphviz->new();

        my $graph = $parser->from_text(
                "digraph MyGraph { \n" .
                "       Bonn -> \"Berlin\" \n }"
        );
        print $graph->as_ascii();

        print $parser->from_file(mygraph.dot)->as_ascii();



DESCRIPTION

Graph::Easy::Parser::Graphviz parses the text format from the DOT language use by Graphviz and constructs a Graph::Easy object from it.

The resulting object can than be used to layout and output the graph in various formats.

Please see the Graphviz manual for a full description of the syntax rules of the DOT language.

    Output

The output will be a Graph::Easy object (unless overrriden with use_class()), see the documentation for Graph::Easy what you can do with it.

    Attributes

Attributes will be remapped to the proper Graph::Easy attribute names and values, as much as possible.

Anything else will be converted to custom attributes starting with x-dot-. So ranksep: 2 will become x-dot-ranksep: 2.

METHODS

Graph::Easy::Parser::Graphviz supports the same methods as its parent class Graph::Easy::Parser:

new()



        use Graph::Easy::Parser::Graphviz;
        my $parser = Graph::Easy::Parser::Graphviz->new();



Creates a new parser object. There are two valid parameters:



        debug
        fatal_errors



Both take either a false or a true value.



        my $parser = Graph::Easy::Parser::Graphviz->new( debug => 1 );
        $parser->from_text(digraph G { A -> B });



reset()



        $parser->reset();



Reset the status of the parser, clear errors etc. Automatically called when you call any of the from_XXX() methods below.

use_class()



        $parser->use_class(node, Graph::Easy::MyNode);



Override the class to be used to constructs objects while parsing.

See Graph::Easy::Parser for further information.

from_text()



        my $graph = $parser->from_text( $text );



Create a Graph::Easy object from the textual description in $text.

Returns undef for error, you can find out what the error was with error().

This method will reset any previous error, and thus the $parser object can be re-used to parse different texts by just calling from_text() multiple times.

from_file()



        my $graph = $parser->from_file( $filename );
        my $graph = Graph::Easy::Parser->from_file( $filename );



Creates a Graph::Easy object from the textual description in the file $filename.

The second calling style will create a temporary parser object, parse the file and return the resulting Graph::Easy object.

Returns undef for error, you can find out what the error was with error() when using the first calling style.

error()



        my $error = $parser->error();



Returns the last error, or the empty string if no error occured.

parse_error()



        $parser->parse_error( $msg_nr, @params);



Sets an error message from a message number and replaces embedded templates like ##param1## with the passed parameters.

CAVEATS

The parser has problems with the following things:
encoding and charset attribute The parser assumes the input to be utf-8. Input files in <code>Latin1</code> are not parsed properly, even when they have the charset attribute set.
shape=record Nodes with shape record are only parsed properly when the label does not contain groups delimited by { and }, so the following is parsed wrongly:



        node1 [ shape=record, label="A|{B|C}" ]



default shape The default shape for a node is ’rect’, opposed to ’circle’ as dot renders nodes.
attributes Some attributes are <B>notB> remapped properly to what Graph::Easy expects, thus losing information, either because Graph::Easy doesn’t support this feature yet, or because the mapping is incomplete.

Some attributes meant only for nodes or edges etc. might be incorrectly applied to other objects, resulting in unnec. warnings while parsing.

Attributes not valid in the original DOT language are silently ignored by dot, but result in a warning when parsing under Graph::Easy. This helps catching all these pesky misspellings, but it’s not yet possible to disable these warnings.

comments Comments written in the source code itself are discarded. If you want to have comments on the graph, clusters, nodes or edges, use the attribute comment. These are correctly read in and stored, and then output into the different formats, too.

EXPORT

Exports nothing.

SEE ALSO

Graph::Easy, Graph::Reader::Dot.

AUTHOR

Copyright (C) 2005 - 2007 by Tels <http://bloodgate.com>

See the LICENSE file for information.

Search for    or go to Top of page |  Section 3 |  Main Index


perl v5.20.3 GRAPH::EASY::PARSER::GRAPHVIZ (3) 2013-05-25

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.