NAME
    Export::Declare - Declarative Exporting, successor of Exporter-Declare.

DESCRIPTION
    Declare exports instead of using package vars. Successor to
    Exporter::Declare which was over complicated. Fully compatible with
    Importer and Exporter.

SYNOPSYS
  DECLARING EXPORTS
        package My::Exporter;
        use Importer 'Export::Declare' => (qw/export exports export_tag export_meta/);

        # You should do one of these, if you do not then 'vars' will be selected
        # automatically.
        export_meta->inject_menu; # Define IMPORTER_MENU
        # and/or
        export_meta->inject_vars; # Define @EXPORT and friends

        # Export an anonymous sub
        export foo => sub { 'foo' };

        # Export package subs
        exports qw/bar baz/;

        # Default export
        export_tag DEFAULT => qw/bat/;

        # Define the subs you are exporting
        sub bar { 'bar' }
        sub baz { 'baz' }
        sub bat { 'bat' }

  CONSUMING EXPORTS
        use Importer 'My::Exporter' => qw/foo bar baz bat/;

    if the exporter imported "import()" from Export::Declare then you can
    use it directly, but this is discouraged.

        use My::Exporter qw/foo bar baz bat/;

  USE + IMPORT
    You can use Export::Declare directly to bring in the tools. You can
    specify "-menu" and/or "-vars" to inject "IMPORTER_MENU()" and/or
    @EXPORT and friends.

        use Export::Declare => qw/-vars -menu export exports/;

EXPORTS
    All exports are optinal, none are exported by default.

    my $meta = export_meta()
        Get the meta-object for the current package.

        This is litterally:

            sub export_meta { Export::Declare::Meta->new(scalar caller) }

    export $NAME
    export $NAME => $REF
        Export the specified symbol. if $REF is specified then it will be
        used as the export. If $REF is not specified then the ref will be
        pulled from the symbol table for the current package.

        $NAME can be a function name, or a symbol name such as '$FOO'. $REF
        if provided must be the same type as the sigil in $NAME. if $NAME
        has no sigil then "&" is assumed.

    exports @NAMES
        @NAMES is a list of symbol names. A symbol name can be a function
        name without a sigil, or it can be any type of veriable with a
        sigil.

    export_tag $TAG => @NAMES
        $TAG can be any valid tag name (same as any variable name, must
        start with a word character, and contain only word characters and
        numbers.

        @NAMES is a list of symbol names. A symbol name can be a function
        name without a sigil, or it can be any type of veriable with a
        sigil.

        The ":DEFAULT" tag is linked to @EXPORT when the meta-data is linked
        with package vars.

        The ":FAIL" tag is linked to @EXPORT_FAIL when the meta-data is
        linked with package vars.

        The ":ALL" tag is linked to @EXPORT_OK when the meta-data is linked
        with package vars. All exports are added to this tag automatically.

    export_gen $NAME => \&GENERATOR
    export_gen $NAME => $GENERATOR
        Specify that $NAME should be exported, and that the $REF should be
        generated dynamically using the specified sub. This sub will be used
        every time something imports $NAME.

        $NAME can be a function name, or a symbol name such as '$FOO'. $REF
        if provided must be the same type as the sigil in $NAME. if $NAME
        has no sigil then "&" is assumed.

        The second argument can be a reference to a subroutine, or it can be
        the name of a sub to call on the current package.

        The sub gets several arguments:

            export_gen foo => sub {
                my ($from_package, $into_package, $symbol_name) = @_;
                ...
                return $REF;
            };

            export_gen bar => '_gen_bar''
            sub _gen_bar {
                my ($from_package, $into_package, $symbol_name) = @_;
                ...
                return $REF;
            }

    export_magic $NAME => sub { ... }
        This allows you to define custom actions to run AFTER an export has
        been injected into the consumers namespace. This is a good place to
        enable parser hooks like with Devel::Declare.

            export_magic foo => sub {
                my $from = shift;    # Should be the package doing the exporting
                my %args = @_;

                my $into      = $args{into};         # Package symbol was exported into
                my $orig_name = $args{orig_name};    # Original name of the export (in the exporter)
                my $new_name  = $args{new_name};     # Name the symbol was imported as
                my $ref       = $args{ref};          # The reference to the symbol

                ...;                                 # whatever you want, return is ignored.
            };

    $CLASS->import(@NAMES)
        This is an optinal "import()" method you can pull into your exporter
        so that people can consume your exports by directly using your
        module.

            package My::Exporter;

            use Importer 'Export::Declare' => qw/export import/;

            export foo => sub { 'foo' };

        ...

            package My::Consumer;

            use My::Exporter qw/foo/;

        This is discouraged! it is better if you omit "import()" and have
        people do this to get your exports:

            package My::Consumer;

            use Importer 'My::Exporter' => qw/foo/;

DETAILS
    This package tracks exports in a meta class. The meta-class is
    Export::Declare::Meta. All the exports act on the meta-object for the
    package that calls them. Having this meta-data on its own does not
    actually make your module an exporter, for that to happen you need to
    expose the meta-data in a way that Exporter or Importer know how to find
    it.

        export_meta->inject_vars;
        export_meta->inject_menu;

    "inject_vars" will inject @EXPORT, @EXPORT_OK and other related vars.
    These vars will be directly linked to the meta-object.

    "inject_menu" injects the "IMPORTER_MENU()" function that exposes the
    meta-data.

    If you do not specify one, then "vars" will be selected for you
    automatically the first time you use an export function.

SOURCE
    The source code repository for Export-Declare can be found at
    http://github.com/exodist/Export-Declare/.

MAINTAINERS
    Chad Granum <exodist@cpan.org>

AUTHORS
    Chad Granum <exodist@cpan.org>

COPYRIGHT
    Copyright 2015 Chad Granum <exodist7@gmail.com>.

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

    See http://dev.perl.org/licenses/