The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
NAME
    Perinci::Import - Import functions from another module

VERSION
    version 0.02

SYNOPSIS
     # import some functions
     use Perinci::Import 'Some::Module', 'func1', 'func2';

     # import wrapped function
     use Perinci::Import 'Some::Function', func1 => {retry => 3};

     # import all (public) functions
     use Perinci::Import 'Some::Module', ':all';

DESCRIPTION
    This module is the counterpart of Perinci::Exporter (with slightly
    incompatible semantic in syntax). It lets you import functions from
    another modules. Imported modules need not define an exporter; the list
    of importable functions, their tags, etc are consulted from Rinci
    metadata (located in %SPEC package variable). Other features include:
    wrapping functions, importing to another name, etc.

    "Perinci::Import" is now preferred over "Perinci::Exporter" as this
    frees module authors from specifying an exporter explicitly. Personally,
    I also use the venerable Exporter on some modules.

IMPORTING
    The basic syntax is:

     use Perinci::Import <MODULE::NAME> [FUNC | FUNC => \%OPTS, ...]

    Default exports. If you specify no arguments:

     use Perinci::Import 'Some::Module';

    this will import all functions having the "default" tag. For example:

     package Some::Module;
     our %SPEC;
     $SPEC{func1} = { v=>1.1, tags=>[qw/default a/] };
     sub   func1    { ... }
     $SPEC{func2} = { v=>1.1, tags=>[qw/default a b/] };
     sub   func2    { ... }
     $SPEC{func3} = { v=>1.1, tags=>[qw/b c/] };
     sub   func3    { ... }
     1;

    "Some::Module" will by default export "f1" and "f2".

    Importing individual functions. You can import individual functions:

     use Perinci::Import 'Some::Module', qw(f1 f2);

    Each function can have import options, specified in a hashref:

     # this imports f1 and f2 (as bar)
     use Perinci::Import 'Some::Module', f1 => {args_as=>'array'}, f2=>{-as=>'bar'};

    Each import key, unless those prefixed by dash ("-") will be passed to
    the "convert" argument of Perinci::Sub::Wrapper's "wrap_sub()". Function
    will be wrapped if one of more such arguments are specified (or "-wrap
    => 1" is given. In the above example, "f1" is wrapped because "args_as"
    is specified. "f2" is not wrapped.

    Importing groups of functions by tags. You can import groups of
    functions using tags. Tags are collected from function metadata, and
    written with a ":" prefix (to differentiate them from function names).
    Each tag can also have import options:

     use YourModule 'f3', ':a' => {-prefix => 'a_'}; # imports f3, a_f1, a_f2

    Some tags are defined automatically: ":default", ":all".

    Importing to a different name. As can be seen from previous examples,
    the "-as" and "-prefix" (and also "-suffix") import options can be used
    to import subroutines using into a different name.

FAQ
TODO/IDEAS
    *   Support combining tags?

         use Perinci::Import 'Some::Module', qw(not(:tag1));
         use Perinci::Import 'Some::Module', qw(and(:tag1,:tag2));
         use Perinci::Import 'Some::Module', qw(or(:tag1,and(:tag2,:tag3)));

    *   Export non-functions (variables, etc).

SEE ALSO
    Perinci, Perinci::Exporter

    Sub::Exporter

HOMEPAGE
    Please visit the project's homepage at
    <https://metacpan.org/release/Perinci-Import>.

SOURCE
    Source repository is at
    <https://github.com/sharyanto/perl-Perinci-Import>.

BUGS
    Please report any bugs or feature requests on the bugtracker website
    <https://rt.cpan.org/Public/Dist/Display.html?Name=Perinci-Import>

    When submitting a bug or request, please include a test-file or a patch
    to an existing test-file that illustrates the bug or desired feature.

AUTHOR
    Steven Haryanto <stevenharyanto@gmail.com>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2014 by Steven Haryanto.

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