Attribute-Overload

 view release on metacpan or  search on metacpan

lib/Attribute/Overload.pm  view on Meta::CPAN

                push @constcode => "$op => \\&$sub";
            } else {
                push @code => "'$op' => \\&$sub";
            }
        }
        next unless @code || @constcode;    # huh? no defs?
        $code .= "package $pkg;\n";
        $code .= "use overload\n" . join(",\n" => @code) . ";\n"
          if @code;

        # Note: the following doesn't do anything, since import()
        # is called at BEGIN via use(), but attributes are only
        # evaluated during CHECK. So it's commented out for now.
        # $code .= "BEGIN { sub import { overload::constant (\n" .
        #     join(",\n" => @constcode) . ")}};\n" if @constcode;
    }

    eval $code if $code;
    die $@ if $@;
}
1;


__END__
=pod

=head1 NAME

Attribute::Overload - Attribute that makes overloading easier

=head1 VERSION

version 1.100710

=head1 SYNOPSIS

  use Attribute::Overload;
  sub add : Overload(+) {
      # ...
  }

=head1 DESCRIPTION

The C<Overload> attribute, when used on a subroutine, declares that subroutine
as the handler in the current package for the operation(s) indicated by the
attribute options. Thus it frees you from the implementation details of how to
declare overloads and keeps the definitions where they belong, with the
operation handlers.

For details of which operations can be overloaded and what the overloading
function gets passed see the L<overload> manpage.

Note that you can't overload constants this way, since this has to happen
during BEGIN time, but attributes are only evaluated at CHECK time, at least
as far as L<Attribute::Handlers> is concerned.

=head1 INSTALLATION

See perlmodinstall for information and options on installing Perl modules.

=head1 BUGS AND LIMITATIONS

No bugs have been reported.

Please report any bugs or feature requests through the web interface at
L<http://rt.cpan.org/Public/Dist/Display.html?Name=Attribute-Overload>.

=head1 AVAILABILITY

The latest version of this module is available from the Comprehensive Perl
Archive Network (CPAN). Visit L<http://www.perl.com/CPAN/> to find a CPAN
site near you, or see
L<http://search.cpan.org/dist/Attribute-Overload/>.

The development version lives at
L<http://github.com/hanekomu/Attribute-Overload/>.
Instead of sending patches, please fork this project using the standard git
and github infrastructure.

=head1 AUTHOR

  Marcel Gruenauer <marcel@cpan.org>

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2001 by Marcel Gruenauer.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.

=cut



( run in 1.209 second using v1.01-cache-2.11-cpan-39bf76dae61 )