X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FLaTeX%2FTikZ%2FMod%2FLayer.pm;h=0dd0a84a76dec2a4b0f06a9c470d9ca253a31de3;hb=af7d6a5aef3bf5fec0c187b3a13a14adc88251fd;hp=ca0b2bd6cc026ae40014d422dbe45317009b1579;hpb=93bfe14caec156fc11587863a486220b986b6b2e;p=perl%2Fmodules%2FLaTeX-TikZ.git diff --git a/lib/LaTeX/TikZ/Mod/Layer.pm b/lib/LaTeX/TikZ/Mod/Layer.pm index ca0b2bd..0dd0a84 100644 --- a/lib/LaTeX/TikZ/Mod/Layer.pm +++ b/lib/LaTeX/TikZ/Mod/Layer.pm @@ -15,10 +15,13 @@ Version 0.01 our $VERSION = '0.01'; -use List::Util (); +use Scalar::Util (); +use List::Util (); use LaTeX::TikZ::Mod::Formatted; +use LaTeX::TikZ::Interface; + use Any::Moose; use Any::Moose 'Util::TypeConstraints'; @@ -78,9 +81,11 @@ around 'new' => sub { if (defined $name) { $self->meta->find_attribute_by_name('name') ->type_constraint->assert_valid($name); - confess("Can't redefine layer '$name'") if keys(%args) > 1; my $layer = $layers{$name}; - return $layer if defined $layer; + if (defined $layer) { + confess("Can't redefine layer '$name'") if keys(%args) > 1; + return $layer; + } } return $self->$orig(%args); @@ -89,7 +94,9 @@ around 'new' => sub { sub BUILD { my ($self) = @_; - $layers{$self->name} = $self; + my $name = $self->name; + $layers{$name} = $self; + Scalar::Util::weaken($layers{$name}); } sub DEMOLISH { @@ -188,11 +195,14 @@ sub apply { ) } -use LaTeX::TikZ::API layer => sub { - shift; +LaTeX::TikZ::Interface->register( + layer => sub { + shift; - __PACKAGE__->new(name => $_[0]); -}; + my $name = shift; + __PACKAGE__->new(name => $name, @_); + }, +); __PACKAGE__->meta->make_immutable( inline_constructor => 0,