diff options
author | Michael G. Schwern <schwern@pobox.com> | 2011-10-22 19:32:04 -0700 |
---|---|---|
committer | Tony Cook <tony@develop-help.com> | 2011-10-29 14:20:44 +1100 |
commit | 01d915c00a066129fc64984cc9323785791fd33c (patch) | |
tree | 3834c3aa7c88b5eb67e45659c1d7d88dfc1ca175 /pod/perlmod.pod | |
parent | 96afcf7e17917e18327f7d8a73e4d04b6dccddc0 (diff) | |
download | perl-01d915c00a066129fc64984cc9323785791fd33c.tar.gz |
Remove unnecessary cruft from the module example.
This makes it more like a real module would be written while retaining it's utility as a teaching boilerplate.
* require Exporter instead of use with no import
* Declare and initialize variables together.
* Eliminate archaic RCS/CVS versioning clutter.
* Explain what @ISA does.
* Remove archaic (and slower) &func syntax from exporting
* Remove %EXPORT_TAGS. It's not explained and rarely used.
* Remove redundant @EXPORT_OK
* Use cleaner $priv_func->() syntax rather than &$priv_func.
* Eliminate prototypes, they're clutter, rarely used and dangerous.
TonyC: update known_pod_issues.dat
Diffstat (limited to 'pod/perlmod.pod')
-rw-r--r-- | pod/perlmod.pod | 61 |
1 files changed, 23 insertions, 38 deletions
diff --git a/pod/perlmod.pod b/pod/perlmod.pod index 336b99c317..33f098d022 100644 --- a/pod/perlmod.pod +++ b/pod/perlmod.pod @@ -404,65 +404,50 @@ create a file called F<Some/Module.pm> and start with this template: use warnings; BEGIN { - use Exporter (); - our ($VERSION, @ISA, @EXPORT, @EXPORT_OK, %EXPORT_TAGS); + require Exporter; # set the version for version checking - $VERSION = 1.00; - # if using RCS/CVS, this may be preferred - $VERSION = sprintf "%d.%03d", q$Revision: 1.1 $ =~ /(\d+)/g; + our $VERSION = 1.00; - @ISA = qw(Exporter); - @EXPORT = qw(&func1 &func2 &func4); - %EXPORT_TAGS = ( ); # eg: TAG => [ qw!name1 name2! ], + # Inherit from Exporter to export functions and variables + our @ISA = qw(Exporter); - # your exported package globals go here, - # as well as any optionally exported functions - @EXPORT_OK = qw($Var1 %Hashit &func3); + # Functions and variables which are exported by default + our @EXPORT = qw(func1 func2); + + # Functions and variables which can be optionally exported + our @EXPORT_OK = qw($Var1 %Hashit func3); } - our @EXPORT_OK; # exported package globals go here - our $Var1; - our %Hashit; + our $Var1 = ''; + our %Hashit = (); # non-exported package globals go here - our @more; - our $stuff; - - # initialize package globals, first exported ones - $Var1 = ''; - %Hashit = (); - - # then the others (which are still accessible as $Some::Module::stuff) - $stuff = ''; - @more = (); + # (they are still accessible as $Some::Module::stuff) + our @more = (); + our $stuff = ''; - # all file-scoped lexicals must be created before - # the functions below that use them. - - # file-private lexicals go here + # file-private lexicals go here, before any functions which use them my $priv_var = ''; my %secret_hash = (); # here's a file-private function as a closure, - # callable as &$priv_func; it cannot be prototyped. + # callable as $priv_func->(); my $priv_func = sub { - # stuff goes here. + ... }; # make all your functions, whether exported or not; # remember to put something interesting in the {} stubs - sub func1 {} # no prototype - sub func2() {} # proto'd void - sub func3($$) {} # proto'd to 2 scalars - - # this one isn't exported, but could be called! - sub func4(\%) {} # proto'd to 1 hash ref + sub func1 { ... } + sub func2 { ... } - END { } # module clean-up code here (global destructor) + # this one isn't exported, but could be called directly + # as Some::Module::func3() + sub func3 { ... } - ## YOUR CODE GOES HERE + END { ... } # module clean-up code here (global destructor) 1; # don't forget to return a true value from the file |