1Graph::Easy::Parser::GrUaspehrviCzo(n3t)ributed Perl DocGurmaepnht:a:tEiaosny::Parser::Graphviz(3)
2
3
4
6 Graph::Easy::Parser::Graphviz - Parse Graphviz text into Graph::Easy
7
9 # creating a graph from a textual description
10
11 use Graph::Easy::Parser::Graphviz;
12 my $parser = Graph::Easy::Parser::Graphviz->new();
13
14 my $graph = $parser->from_text(
15 "digraph MyGraph { \n" .
16 " Bonn -> \"Berlin\" \n }"
17 );
18 print $graph->as_ascii();
19
20 print $parser->from_file('mygraph.dot')->as_ascii();
21
23 "Graph::Easy::Parser::Graphviz" parses the text format from the DOT
24 language use by Graphviz and constructs a "Graph::Easy" object from it.
25
26 The resulting object can than be used to layout and output the graph in
27 various formats.
28
29 Please see the Graphviz manual for a full description of the syntax
30 rules of the DOT language.
31
32 Output
33 The output will be a Graph::Easy object (unless overridden with
34 use_class()), see the documentation for Graph::Easy what you can do
35 with it.
36
37 Attributes
38 Attributes will be remapped to the proper Graph::Easy attribute names
39 and values, as much as possible.
40
41 Anything else will be converted to custom attributes starting with
42 "x-dot-". So "ranksep: 2" will become "x-dot-ranksep: 2".
43
45 "Graph::Easy::Parser::Graphviz" supports the same methods as its parent
46 class "Graph::Easy::Parser":
47
48 new()
49 use Graph::Easy::Parser::Graphviz;
50 my $parser = Graph::Easy::Parser::Graphviz->new();
51
52 Creates a new parser object. There are two valid parameters:
53
54 debug
55 fatal_errors
56
57 Both take either a false or a true value.
58
59 my $parser = Graph::Easy::Parser::Graphviz->new( debug => 1 );
60 $parser->from_text('digraph G { A -> B }');
61
62 reset()
63 $parser->reset();
64
65 Reset the status of the parser, clear errors etc. Automatically called
66 when you call any of the from_XXX() methods below.
67
68 use_class()
69 $parser->use_class('node', 'Graph::Easy::MyNode');
70
71 Override the class to be used to constructs objects while parsing.
72
73 See Graph::Easy::Parser for further information.
74
75 from_text()
76 my $graph = $parser->from_text( $text );
77
78 Create a Graph::Easy object from the textual description in $text.
79
80 Returns undef for error, you can find out what the error was with
81 error().
82
83 This method will reset any previous error, and thus the $parser object
84 can be re-used to parse different texts by just calling from_text()
85 multiple times.
86
87 from_file()
88 my $graph = $parser->from_file( $filename );
89 my $graph = Graph::Easy::Parser->from_file( $filename );
90
91 Creates a Graph::Easy object from the textual description in the file
92 $filename.
93
94 The second calling style will create a temporary parser object, parse
95 the file and return the resulting "Graph::Easy" object.
96
97 Returns undef for error, you can find out what the error was with
98 error() when using the first calling style.
99
100 error()
101 my $error = $parser->error();
102
103 Returns the last error, or the empty string if no error occurred.
104
105 parse_error()
106 $parser->parse_error( $msg_nr, @params);
107
108 Sets an error message from a message number and replaces embedded
109 templates like "##param1##" with the passed parameters.
110
112 The parser has problems with the following things:
113
114 encoding and charset attribute
115 The parser assumes the input to be "utf-8". Input files in
116 <code>Latin1</code> are not parsed properly, even when they
117 have the charset attribute set.
118
119 shape=record
120 Nodes with shape record are only parsed properly when the
121 label does not contain groups delimited by "{" and "}", so
122 the following is parsed wrongly:
123
124 node1 [ shape=record, label="A|{B|C}" ]
125
126 default shape
127 The default shape for a node is 'rect', opposed to 'circle'
128 as dot renders nodes.
129
130 attributes Some attributes are not remapped properly to what
131 Graph::Easy expects, thus losing information, either
132 because Graph::Easy doesn't support this feature yet, or
133 because the mapping is incomplete.
134
135 Some attributes meant only for nodes or edges etc. might be
136 incorrectly applied to other objects, resulting in unnec.
137 warnings while parsing.
138
139 Attributes not valid in the original DOT language are
140 silently ignored by dot, but result in a warning when
141 parsing under Graph::Easy. This helps catching all these
142 pesky misspellings, but it's not yet possible to disable
143 these warnings.
144
145 comments Comments written in the source code itself are discarded.
146 If you want to have comments on the graph, clusters, nodes
147 or edges, use the attribute "comment". These are correctly
148 read in and stored, and then output into the different
149 formats, too.
150
152 Exports nothing.
153
155 Graph::Easy, Graph::Reader::Dot.
156
158 Copyright (C) 2005 - 2007 by Tels <http://bloodgate.com>
159
160 See the LICENSE file for information.
161
162
163
164perl v5.36.0 2023-02-02 Graph::Easy::Parser::Graphviz(3)