X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FLaTeX%2FTikZ%2FMod.pm;h=6138e5b4033a004f43a33cfa149aca32ef9e2533;hb=3661d7849ae4636b74000e33e068493d90ed8337;hp=b5921e9bcd3199d79b662e84a1481804e56af81c;hpb=17bd99ecff97751a8323f7f89a97bacb7cd29ec2;p=perl%2Fmodules%2FLaTeX-TikZ.git diff --git a/lib/LaTeX/TikZ/Mod.pm b/lib/LaTeX/TikZ/Mod.pm index b5921e9..6138e5b 100644 --- a/lib/LaTeX/TikZ/Mod.pm +++ b/lib/LaTeX/TikZ/Mod.pm @@ -9,26 +9,72 @@ LaTeX::TikZ::Mod - Base role for LaTeX::TikZ modifiers. =head1 VERSION -Version 0.01 +Version 0.02 =cut -our $VERSION = '0.01'; +our $VERSION = '0.02'; -use Any::Moose 'Role'; -use Any::Moose 'Util::TypeConstraints'; +=head1 DESCRIPTION -requires qw( +This role should be consumed by all the modifier classes. + +=cut + +use Mouse::Role; +use Mouse::Util::TypeConstraints; + +=head1 METHODS + +These methods are required by the interface : + +=over 4 + +=item * + +C + +Returns an identifier for the mod object. +It is used to gather mods together when calling C on them. + +=item * + +C + +Returns true if and only if the effects of the mod C<$mod> are already ensured by the current mod object, in which case no actual TikZ code will be emitted for C<$mod>. +Both mod objects are guaranteed to have the same C. + +=item * + +C + +Returns an array reference of TikZ code lines required to declare this mod before using it, formatted by the L object C<$formatter> ; or C if no declarations are needed for this mod. + +=item * + +C + +Returns the TikZ code that activates the current mod as a string formatted by the L object C<$formatter>. + +=back + +=cut + +requires qw< tag - cover + covers declare apply -); +>; coerce 'LaTeX::TikZ::Mod' => from 'Str' => via { LaTeX::TikZ::Mod::Raw->new(content => $_) }; +=head1 SEE ALSO + +L. + =head1 AUTHOR Vincent Pit, C<< >>, L.