NAME
    Exporter::Handy - An EXPERIMENTAL subclass of <Exporter::Extensible>,
    which helps create easy-to-extend modules that export symbols

VERSION
    version 0.200000

SYNOPSIS
    Define a module with exports

      package My::Utils;
      use Exporter::Handy -exporter_setup => 1;

      export(qw( foo $x @STUFF -strict_and_warnings ), ':baz' => ['foo'] );

      sub foo { ... }

      sub strict_and_warnings {
        strict->import;
        warnings->import;
      }

    Create a new module which exports all that, and more

      package My::MoreUtils;
      use My::Utils -exporter_setup => 1;
      sub util_fn3 : Export(:baz) { ... }

    Use the module

      use My::MoreUtils qw( -strict_and_warnings :baz @STUFF );
      # Use the exported things
      push @STUFF, foo(), util_fn3();

DESCRIPTION
    This module is currently EXPERIMENTAL. You are advised to restrain from
    using it.

    You have been warned.

FUNCTIONS
  xtags
    Build one or more export tags suitable for Exporter::Handy,
    Exporter::Extensible and co.

        use Exporter::Handy -exporter_setup => 1, xtags;

        export(
            foo
            baz
            xtags(
              bar => [qw( $bozo @baza boom )],
            ),
        );

OPTIONS
  strict, warnings, feature, utf8
    The below statement:

        use Exporter::Handy -strict;

    is equivalent to: use Exporter::Handy; use strict;

    Same thing for "feature", "warnings", "utf8";

  strictures
    The below statement:

        use Exporter::Handy -strictures;

    is equivalent to: use Exporter::Handy; use strict; use warnings;

  sane
    The below statement:

        use Exporter::Handy -sane;

    is equivalent to: use Exporter::Handy; use strict; use warnings;

  features
    The below statement:

        use Exporter::Handy -features;

    is equivalent to: use Exporter::Handy; use feature ( 'current_sub', #
    Perl v5.16+ (2012) : enable __SUB__ token that returns a ref to the
    current subroutine (or undef). 'evalbytes', # Perl v5.16+ (2012) : like
    string eval, but it treats its argument as a byte string. 'fc', # Perl
    v5.16+ (2012) : enable the fc function (Unicode casefolding).
    'lexical_subs', # Perl v5.18+ (2012) : enable declaration of subroutines
    via my sub foo, state sub foo and our sub foo syntax. 'say', # Perl
    v5.10+ (2007) : enable the Raku-inspired "say" function. 'state', # Perl
    v5.10+ (2007) : enable state variables. 'unicode_eval', # Perl v5.16+
    (2012) : changes the behavior of plain string eval to work more
    consistently, especially in the Unicode world. 'unicode_strings', # Perl
    v5.12+ (2010) : use Unicode rules in all string operations (unless
    either use locale or use bytes are also within the scope). );

    whereas the below statement:

        use Exporter::Handy -features => [qw(say)];

    is equivalent to:

        use Exporter::Handy;
        use feature (
          'say',              # Perl v5.10+ (2007) : enable the Raku-inspired "say" function.
        );

AUTHORS
    Tabulo[n] <dev@tabulo.net>

SUPPORT
  Bugs / Feature Requests
    Please report any bugs or feature requests through the issue tracker at
    <https://github.com/tabulon-perl/p5-Exporter-Handy/issues>.

  Source Code
    This is open source software. The code repository is available for
    public review and contribution under the terms of the license.

    <https://github.com/tabulon-perl/p5-Exporter-Handy>

      git clone https://github.com/tabulon-perl/p5-Exporter-Handy.git

CONTRIBUTOR
    Tabulo <dev-git.perl@tabulo.net>

LEGAL
    This software is copyright (c) 2023 by Tabulo[n].

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