]> git.vpit.fr Git - perl/modules/LaTeX-TikZ.git/blob - lib/LaTeX/TikZ/Set/Path.pm
Introduce the ->begin and ->end path methods
[perl/modules/LaTeX-TikZ.git] / lib / LaTeX / TikZ / Set / Path.pm
1 package LaTeX::TikZ::Set::Path;
2
3 use strict;
4 use warnings;
5
6 =head1 NAME
7
8 LaTeX::TikZ::Set::Path - A role for set objects that can be part of a path.
9
10 =head1 VERSION
11
12 Version 0.02
13
14 =cut
15
16 our $VERSION = '0.02';
17
18 =head1 DESCRIPTION
19
20 Paths are all the elements against which we can call the C<path> method.
21
22 =cut
23
24 use Any::Moose 'Role';
25
26 =head1 RELATIONSHIPS
27
28 This role consumes the L<LaTeX::TikZ::Set> role, and as such implements the L</draw> method.
29
30 =cut
31
32 with 'LaTeX::TikZ::Set';
33
34 =head1 METHODS
35
36 These methods are required by the interface :
37
38 =over 4
39
40 =item *
41
42 C<path $formatter>
43
44 Returns the TikZ code that builds a path out of the current set object as a string formatted by the L<LaTeX::TikZ::Formatter> object C<$formatter>.
45
46 =item *
47
48 C<begin>
49
50 Returns a L<LaTeX::TikZ::Point> object pointing to the beginning of the path, or C<undef> if this path has no beginning.
51
52 =item *
53
54 C<end>
55
56 A L<LaTeX::TikZ::Point> object pointing to the end of the path, or C<undef> if this path has no end.
57
58 =back
59
60 =cut
61
62 requires qw<
63  path
64  begin
65  end
66 >;
67
68 =head2 C<draw>
69
70 =cut
71
72 sub draw {
73  my $set = shift;
74
75  [ "\\draw " . $set->path(@_) . ' ;' ];
76 }
77
78 =head1 SEE ALSO
79
80 L<LaTeX::TikZ>, L<LaTeX::TikZ::Set>.
81
82 =head1 AUTHOR
83
84 Vincent Pit, C<< <perl at profvince.com> >>, L<http://www.profvince.com>.
85
86 You can contact me by mail or on C<irc.perl.org> (vincent).
87
88 =head1 BUGS
89
90 Please report any bugs or feature requests to C<bug-latex-tikz at rt.cpan.org>, or through the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=LaTeX-TikZ>.
91 I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
92
93 =head1 SUPPORT
94
95 You can find documentation for this module with the perldoc command.
96
97     perldoc LaTeX::TikZ
98
99 =head1 COPYRIGHT & LICENSE
100
101 Copyright 2010 Vincent Pit, all rights reserved.
102
103 This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
104
105 =cut
106
107 1; # End of LaTeX::TikZ::Set::Path;