=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
use LaTeX::TikZ::Set::Point;
+use LaTeX::TikZ::Interface;
+use LaTeX::TikZ::Functor;
+
use Any::Moose;
use Any::Moose 'Util::TypeConstraints';
+=head1 RELATIONSHIPS
+
+This class consumes the L<LaTeX::TikZ::Set::Op> role, and as such implements the L</path> method.
+
+=cut
+
with 'LaTeX::TikZ::Set::Op';
subtype 'LaTeX::TikZ::Set::Polyline::Vertices'
=> from 'ArrayRef[Any]'
=> via { [ map LaTeX::TikZ::Set::Point->new(point => $_), @$_ ] };
+=head1 ATTRIBUTES
+
+=head2 C<points>
+
+The list of the successive vertices of the path.
+
+=cut
+
has '_points' => (
is => 'ro',
isa => 'LaTeX::TikZ::Set::Polyline::Vertices',
sub points { @{$_[0]->_points} }
+=head2 C<closed>
+
+A boolean that indicates whether the path is closed or not.
+
+=cut
+
has 'closed' => (
is => 'ro',
isa => 'Bool',
default => 0,
);
+=head1 METHODS
+
+=head2 C<path>
+
+=cut
+
sub path {
my $set = shift;
($set->closed ? 'cycle' : ());
}
-use LaTeX::TikZ::Interface polyline => sub {
- shift;
+LaTeX::TikZ::Interface->register(
+ polyline => sub {
+ shift;
- __PACKAGE__->new(points => \@_);
-};
+ __PACKAGE__->new(points => \@_);
+ },
+ closed_polyline => sub {
+ shift;
-use LaTeX::TikZ::Interface closed_polyline => sub {
- shift;
+ __PACKAGE__->new(points => \@_, closed => 1);
+ },
+);
- __PACKAGE__->new(points => \@_, closed => 1);
-};
+LaTeX::TikZ::Functor->default_rule(
+ (__PACKAGE__) => sub {
+ my ($functor, $set, @args) = @_;
+ $set->new(
+ points => [ map $_->$functor(@args), $set->points ],
+ closed => $set->closed,
+ );
+ }
+);
__PACKAGE__->meta->make_immutable;
+=head1 SEE ALSO
+
+L<LaTeX::TikZ>, L<LaTeX::TikZ::Set::Op>.
+
=head1 AUTHOR
Vincent Pit, C<< <perl at profvince.com> >>, L<http://www.profvince.com>.