I have two modules that use scalar objects:
package OnDestroy;
BEGIN {
our @EXPORT = qw( on_destroy );
require Exporter;
*import = \&Exporter::import;
}
sub on_destroy(&) {
my ($action) = @_;
return bless(\$action);
}
sub cancel {
my ($self) = @_;
undef $$self;
}
sub DESTROY {
my ($self) = @_;
my $action = $$self;
$action->() if $action;
}
1;
and something I wrote in reponse to a question on PerlMonks:
package AutoExecute;
BEGIN {
our @EXPORT = qw( auto_execute );
require Exporter;
*import = \&Exporter::import;
}
use overload
'""' => \&stringify,
'&{}' => \&code_ref,
;
sub auto_execute(&) {
my ($sub) = @_;
return bless(\$sub);
}
sub new {
my ($class, $sub) = @_;
return bless(\$sub, $class);
}
sub stringify {
my ($self) = @_;
my $sub = $$self;
return $sub->();
}
sub code_ref {
my ($self) = @_;
my $sub = $$self;
return $sub;
}
1;
All my other objects are based on arrays.
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.
|