maint: Configure Emacs automatically with ".dir-locals.el"
[automake.git] / lib / Automake / Getopt.pm
blob6236b78ac82b52146bf2e6c13d14666cdef64391
1 # Copyright (C) 2012-2017 Free Software Foundation, Inc.
3 # This program is free software: you can redistribute it and/or modify
4 # it under the terms of the GNU General Public License as published by
5 # the Free Software Foundation, either version 3 of the License, or
6 # (at your option) any later version.
8 # This program is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # GNU General Public License for more details.
13 # You should have received a copy of the GNU General Public License
14 # along with this program. If not, see <https://www.gnu.org/licenses/>.
16 package Automake::Getopt;
18 =head1 NAME
20 Automake::Getopt - GCS conforming parser for command line options
22 =head1 SYNOPSIS
24 use Automake::Getopt;
26 =head1 DESCRIPTION
28 Export a function C<parse_options>, performing parsing of command
29 line options in conformance to the GNU Coding standards.
31 =cut
33 use 5.006;
34 use strict;
35 use warnings FATAL => 'all';
36 use Exporter ();
37 use Getopt::Long ();
38 use Automake::ChannelDefs qw/fatal/;
39 use Carp qw/croak confess/;
41 use vars qw (@ISA @EXPORT);
42 @ISA = qw (Exporter);
43 @EXPORT= qw/getopt/;
45 =item C<parse_options (%option)>
47 Wrapper around C<Getopt::Long>, trying to conform to the GNU
48 Coding Standards for error messages.
50 =cut
52 sub parse_options (%)
54 my %option = @_;
56 Getopt::Long::Configure ("bundling", "pass_through");
57 # Unrecognized options are passed through, so GetOption can only fail
58 # due to internal errors or misuse of options specification.
59 Getopt::Long::GetOptions (%option)
60 or confess "error in options specification (likely)";
62 if (@ARGV && $ARGV[0] =~ /^-./)
64 my %argopts;
65 for my $k (keys %option)
67 if ($k =~ /(.*)=s$/)
69 map { $argopts{(length ($_) == 1)
70 ? "-$_" : "--$_" } = 1; } (split (/\|/, $1));
73 if ($ARGV[0] eq '--')
75 shift @ARGV;
77 elsif (exists $argopts{$ARGV[0]})
79 fatal ("option '$ARGV[0]' requires an argument\n"
80 . "Try '$0 --help' for more information.");
82 else
84 fatal ("unrecognized option '$ARGV[0]'.\n"
85 . "Try '$0 --help' for more information.");
90 =back
92 =head1 SEE ALSO
94 L<Getopt::Long>
96 =cut
98 1; # for require