.\" Automatically generated by Pod::Man 2.28 (Pod::Simple 3.28) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is turned on, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .nr rF 0 .if \n(.g .if rF .nr rF 1 .if (\n(rF:(\n(.g==0)) \{ . if \nF \{ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{ . nr % 0 . nr F 2 . \} . \} .\} .rr rF .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "Sub::Exporter::ForMethods 3pm" .TH Sub::Exporter::ForMethods 3pm "2015-07-17" "perl v5.20.2" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" Sub::Exporter::ForMethods \- helper routines for using Sub::Exporter to build methods .SH "VERSION" .IX Header "VERSION" version 0.100052 .SH "SYNOPSIS" .IX Header "SYNOPSIS" In an exporting library: .PP .Vb 1 \& package Method::Builder; \& \& use Sub::Exporter::ForMethods qw(method_installer); \& \& use Sub::Exporter \-setup => { \& exports => [ method => \e\*(Aq_method_generator\*(Aq ], \& installer => method_installer, \& }; \& \& sub _method_generator { \& my ($self, $name, $arg, $col) = @_; \& return sub { ... }; \& }; .Ve .PP In an importing library: .PP .Vb 2 \& package Vehicle::Autobot; \& use Method::Builder method => { \-as => \*(Aqtransform\*(Aq }; .Ve .SH "DESCRIPTION" .IX Header "DESCRIPTION" The synopsis section, above, looks almost indistinguishable from any other use of Sub::Exporter, apart from the use of \&\f(CW\*(C`method_installer\*(C'\fR. It is nearly indistinguishable in behavior, too. The only change is that subroutines exported from Method::Builder into named slots in Vehicle::Autobot will be wrapped in a subroutine called \&\f(CW\*(C`Vehicle::Autobot::transform\*(C'\fR. This will insert a named frame into stack traces to aid in debugging. .PP More importantly (for the author, anyway), they will not be removed by namespace::autoclean. This makes the following code work: .PP .Vb 1 \& package MyLibrary; \& \& use Math::Trig qw(tan); # uses Exporter.pm \& use String::Truncate qw(trunc); # uses Sub::Exporter\*(Aqs defaults \& \& use Sub::Exporter::ForMethods qw(method_installer); \& use Mixin::Linewise { installer => method_installer }, qw(read_file); \& \& use namespace::autoclean; \& \& ... \& \& 1; .Ve .PP After MyLibrary is compiled, \f(CW\*(C`namespace::autoclean\*(C'\fR will remove \f(CW\*(C`tan\*(C'\fR and \&\f(CW\*(C`trunc\*(C'\fR as foreign contaminants, but will leave \f(CW\*(C`read_file\*(C'\fR in place. It will also remove \f(CW\*(C`method_installer\*(C'\fR, an added win. .SH "EXPORTS" .IX Header "EXPORTS" Sub::Exporter::ForMethods offers only one routine for export, and it may also be called by its full package name: .SS "method_installer" .IX Subsection "method_installer" .Vb 1 \& my $installer = method_installer(\e%arg); .Ve .PP This routine returns an installer suitable for use as the \f(CW\*(C`installer\*(C'\fR argument to Sub::Exporter. It updates the \f(CW\*(C`\e@to_export\*(C'\fR argument to wrap all code that will be installed by name in a named subroutine, then passes control to the default Sub::Exporter installer. .PP The only argument to \f(CW\*(C`method_installer\*(C'\fR is an optional hashref which may contain a single entry for \f(CW\*(C`rebless\*(C'\fR. If the value for \f(CW\*(C`rebless\*(C'\fR is true, when a blessed subroutine is wrapped, the wrapper will be blessed into the same package. .SH "AUTHOR" .IX Header "AUTHOR" Ricardo Signes .SH "COPYRIGHT AND LICENSE" .IX Header "COPYRIGHT AND LICENSE" This software is copyright (c) 2015 by Ricardo Signes. .PP This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.