NAME

Getopt::Long::EvenLess - Like Getopt::Long::Less, but with even less features

VERSION

This document describes version 0.07 of Getopt::Long::EvenLess (from Perl distribution Getopt-Long-EvenLess), released on 2016-12-03.

DESCRIPTION

EXPERIMENTAL WORK.

This module (GLEL for short) is a reimplementation of Getopt::Long (GL for short), but with much less features. It's an even more stripped down version of Getopt::Long::Less (GLL for short) and is perhaps less convenient to use for day-to-day scripting work.

The main goal is minimum amount of code and small startup overhead. This module is an experiment of how little code I can use to support the stuffs I usually do with GL.

Compared to GL and GLL, it:

  • does not have Configure()

    Nothing to configure, no different modes of operation. GLEL is equivalent to GL in this mode: bundling, no_ignore_case, no_getopt_compat, gnu_compat, permute.

  • does not support increment (foo+)

  • no type checking (foo=i, foo=f, foo=s all accept any string)

  • does not support optional value (foo:s), only no value (foo) or required value (foo=s)

  • does not support desttypes (foo=s@)

  • does not support handler other than coderef (so no "foo=s" => \$scalar, "foo=s" => \@ary, only "foo=s" => sub { ... })

    Also, in coderef handler, code will get a simple hash instead of a "callback" object as its first argument.

  • does not support hashref as first argument

  • does not support bool/negation (no foo!, so you have to declare both foo and no-foo manually)

The result?

Amount of code. GLEL is about 175 lines of code, while GL is about 1500. Sure, if you really want to be minimalistic, you can use this single line of code to get options:

@ARGV = grep { /^--([^=]+)(=(.*))?/ ? ($opts{$1} = $2 ? $3 : 1, 0) : 1 } @ARGV;

and you're already able to extract --flag or --opt=val from @ARGV but you also lose a lot of stuffs like autoabbreviation, --opt val syntax support syntax (which is more common, but requires you specify an option spec), custom handler, etc.

Startup overhead. Here's a sample startup overhead benchmark:

                           Rate      run_gl     load_gl   run_gl_less  load_gl_less run_gl_evenless load_gl_evenless   perl
run_gl            76.33+-0.31/s          --       -1.2%        -67.0%        -67.6%          -80.7%           -80.9% -87.5%
load_gl           77.29+-0.31/s 1.26+-0.58%          --        -66.6%        -67.2%          -80.5%           -80.6% -87.4%
run_gl_less      231.56+-0.31/s 203.4+-1.3% 199.6+-1.3%            --         -1.8%          -41.4%           -42.0% -62.1%
load_gl_less     235.76+-0.29/s 208.9+-1.3%   205+-1.3%   1.81+-0.19%            --          -40.4%           -41.0% -61.4%
run_gl_evenless    395.4+-2.2/s   418+-3.5% 411.5+-3.5%  70.74+-0.96%   67.7+-0.94%              --            -1.0% -35.3%
load_gl_evenless   399.4+-1.1/s 423.2+-2.6% 416.7+-2.5%  72.48+-0.53%  69.41+-0.51%     1.02+-0.62%               -- -34.7%
perl               611.2+-1.1/s 700.7+-3.6% 690.8+-3.5% 163.95+-0.61% 159.25+-0.58%     54.59+-0.9%     53.03+-0.51%     --

Average times:
  perl            :     1.6361ms
  load_gl_evenless:     2.5038ms
  run_gl_evenless :     2.5291ms
  load_gl_less    :     4.2416ms
  run_gl_less     :     4.3185ms
  load_gl         :    12.9383ms
  run_gl          :    13.1010ms

HOMEPAGE

Please visit the project's homepage at https://metacpan.org/release/Getopt-Long-EvenLess.

SOURCE

Source repository is at https://github.com/perlancar/perl-Getopt-Long-EvenLess.

BUGS

Please report any bugs or feature requests on the bugtracker website https://rt.cpan.org/Public/Dist/Display.html?Name=Getopt-Long-EvenLess

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.

SEE ALSO

Getopt::Long

Getopt::Long::Less

If you want more features intead of less, try Getopt::Long::More.

AUTHOR

perlancar <perlancar@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2016 by perlancar@cpan.org.

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