X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FLaTeX%2FTikZ%2FSet%2FPoint.pm;h=5bf292b10ca11bffccb4c1b26c90af74f803a5e2;hb=af7d6a5aef3bf5fec0c187b3a13a14adc88251fd;hp=0a4911f88a80787829c5212db41d5eeb2174ae2e;hpb=1e3e6b3727cdc2b8ed3c5cbe9a4a36ac7a15c4a2;p=perl%2Fmodules%2FLaTeX-TikZ.git diff --git a/lib/LaTeX/TikZ/Set/Point.pm b/lib/LaTeX/TikZ/Set/Point.pm index 0a4911f..5bf292b 100644 --- a/lib/LaTeX/TikZ/Set/Point.pm +++ b/lib/LaTeX/TikZ/Set/Point.pm @@ -17,6 +17,9 @@ our $VERSION = '0.01'; use LaTeX::TikZ::Point; +use LaTeX::TikZ::Interface; +use LaTeX::TikZ::Functor; + use Any::Moose; use Any::Moose 'Util::TypeConstraints'; @@ -27,12 +30,17 @@ has 'point' => ( isa => 'LaTeX::TikZ::Point::Autocoerce', required => 1, coerce => 1, + handles => [ qw/x y/ ], ); coerce 'LaTeX::TikZ::Set::Point' => from 'Any' => via { __PACKAGE__->new(point => $_) }; +coerce 'LaTeX::TikZ::Point::Autocoerce' + => from 'LaTeX::TikZ::Set::Point' + => via { $_->point }; + sub path { my ($set, $tikz) = @_; @@ -41,11 +49,23 @@ sub path { '(' . $tikz->len($p->x) . ',' . $tikz->len($p->y) . ')'; } -use LaTeX::TikZ::Interface point => sub { - shift; +LaTeX::TikZ::Interface->register( + point => sub { + shift; - __PACKAGE__->new(point => @_ > 1 ? \@_ : $_[0] ); -}; + my $point = @_ == 0 ? 0 + : @_ == 1 ? $_[0] + : \@_; + __PACKAGE__->new(point => $point); + }, +); + +LaTeX::TikZ::Functor->default_rule( + (__PACKAGE__) => sub { + my ($functor, $set, @args) = @_; + $set->new(point => $set->point); + } +); __PACKAGE__->meta->make_immutable;