Carp-Clan-Share

 view release on metacpan or  search on metacpan

lib/Carp/Clan/Share.pm  view on Meta::CPAN

package Carp::Clan::Share;

use warnings;
use strict;

=head1 NAME

Carp::Clan::Share - Share your Carp::Clan settings with your whole Clan

=head1 VERSION

Version 0.013

=cut

our $VERSION = '0.013';

require Carp::Clan;

sub import {
    my $caller = caller(0);
    my @arguments = @_;
    shift @arguments; # Get rid of the package name
    $caller =~ s/::Carp$//; # If the user already named it Carp, use the parent of that.
    unshift @arguments, "^${caller}::";

    my $package = "${caller}::Carp";
    my $pm = join("/", split m/::/, $package) . ".pm";
    $INC{$pm} = 1;
    eval "package $package;";

    my $exporter;
    {
        no strict 'refs';
        $exporter = *{"${package}::import"} = sub {
            push @_, @arguments;
            goto &Carp::Clan::import;
        };
    }

    goto &$exporter;
}

=head1 SYNOPSIS

    package My::Namespace

    use Carp::Clan::Share; # My::Namespace::Carp now exists

    ...

    package My::Namespace::Module

    use My::Namespace::Carp; # Acts like "use Carp::Clan qw/^My::Namespace::/;"

    ...

    package My::Other::Namespace;

    # You can also pass options through to Carp::Clan
    use Carp::Clan::Share qw/verbose/; # My::Other::Namespace::Carp now exists

    ...

    package My::Other::Namespace::Module

    use My::Other::Namespace::Carp; # Acts like "use Carp::Clan qw/^My::Other::Namespace:: verbose/;"

    ...

=head1 DESCRIPTION

This is a very lightweight helper module (actually just an import method) that will automagically create
a __PACKAGE__::Carp module for you.

Any arguments passed to the import (e.g. via use) method are forwarded along to Carp::Clan.

NOTE: If you use this from a package ending with ::Carp, then it will use the parent of of that package
as the target namespace

    package My::Namespace::Carp;
    
    use Carp::Clan::Share;

    package My::Namespace::Module

    use My::Namespace::Carp; # Acts like "use Carp::Clan qw/^My::Namespace::/;"



( run in 0.570 second using v1.01-cache-2.11-cpan-d7a12ab2c7f )