X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FLaTeX%2FTikZ%2FSet%2FPolyline.pm;h=627fd81080b7bd69e95430d0436afcd86cb1996d;hb=93edf9c5c04a04fbd3c8dbf04eacaf66736ff6ee;hp=76656afc88c4c89ac4e0234f458b63b49f2f86b6;hpb=92147217516a40b35ca00c8e08939e8aa5478426;p=perl%2Fmodules%2FLaTeX-TikZ.git diff --git a/lib/LaTeX/TikZ/Set/Polyline.pm b/lib/LaTeX/TikZ/Set/Polyline.pm index 76656af..627fd81 100644 --- a/lib/LaTeX/TikZ/Set/Polyline.pm +++ b/lib/LaTeX/TikZ/Set/Polyline.pm @@ -5,24 +5,31 @@ use warnings; =head1 NAME -LaTeX::TikZ::Set::Polyline - A set object representing a line. +LaTeX::TikZ::Set::Polyline - A set object representing a possibly closed path composed of contiguous lines. =head1 VERSION -Version 0.01 +Version 0.02 =cut -our $VERSION = '0.01'; +our $VERSION = '0.02'; use LaTeX::TikZ::Set::Point; +use LaTeX::TikZ::Interface; use LaTeX::TikZ::Functor; -use Any::Moose; -use Any::Moose 'Util::TypeConstraints'; +use Mouse; +use Mouse::Util::TypeConstraints; -with 'LaTeX::TikZ::Set::Op'; +=head1 RELATIONSHIPS + +This class is a subclass of L, and as such inherits its C method. + +=cut + +extends 'LaTeX::TikZ::Set::Chain'; subtype 'LaTeX::TikZ::Set::Polyline::Vertices' => as 'ArrayRef[LaTeX::TikZ::Set::Point]' @@ -33,7 +40,15 @@ coerce 'LaTeX::TikZ::Set::Polyline::Vertices' => from 'ArrayRef[Any]' => via { [ map LaTeX::TikZ::Set::Point->new(point => $_), @$_ ] }; -has '_points' => ( +=head1 ATTRIBUTES + +=head2 C + +The list of L objects (or scalars that coerce into such objects) that make the successive vertices of the path. + +=cut + +has '+_kids' => ( is => 'ro', isa => 'LaTeX::TikZ::Set::Polyline::Vertices', init_arg => 'points', @@ -41,38 +56,57 @@ has '_points' => ( coerce => 1, ); -sub points { @{$_[0]->_points} } +=head2 C + +A boolean that indicates whether the polyline is closed or not. + +=cut has 'closed' => ( - is => 'ro', - isa => 'Bool', - default => 0, + is => 'ro', + isa => 'Bool', + required => 1, + default => 0, ); -sub path { - my $set = shift; +sub points { @{$_[0]->_kids} } - join ' -- ', map($_->path(@_), $set->points), - ($set->closed ? 'cycle' : ()); -} +around 'BUILDARGS' => sub { + my ($orig, $class, %args) = @_; -use LaTeX::TikZ::Interface polyline => sub { - shift; + delete $args{cycle}; - __PACKAGE__->new(points => \@_); + $class->$orig( + %args, + connector => '--', + cycle => $args{closed}, + ); }; -use LaTeX::TikZ::Interface closed_polyline => sub { - shift; +LaTeX::TikZ::Interface->register( + polyline => sub { + shift; - __PACKAGE__->new(points => \@_, closed => 1); -}; + __PACKAGE__->new( + points => \@_, + closed => 0, + ); + }, + closed_polyline => sub { + shift; + + __PACKAGE__->new( + points => \@_, + closed => 1, + ); + }, +); LaTeX::TikZ::Functor->default_rule( (__PACKAGE__) => sub { my ($functor, $set, @args) = @_; $set->new( - points => [ map $_->$functor(@args), $set->points ], + points => [ map $_->$functor(@args), $set->kids ], closed => $set->closed, ); } @@ -80,6 +114,10 @@ LaTeX::TikZ::Functor->default_rule( __PACKAGE__->meta->make_immutable; +=head1 SEE ALSO + +L, L. + =head1 AUTHOR Vincent Pit, C<< >>, L.