3 # Debhelper option processing library.
5 # Joey Hess GPL copyright 1998-2002
7 package Debian::Debhelper::Dh_Getopt;
10 use Debian::Debhelper::Dh_Lib;
16 my $prog=basename($0);
17 print "Usage: $prog [options]\n\n";
18 print " $prog is a part of debhelper. See debhelper(7)\n";
19 print " and $prog(1) for complete usage instructions.\n";
23 # Passed an option name and an option value, adds packages to the list
24 # of packages. We need this so the list will be built up in the right
26 sub AddPackage { my($option,$value)=@_;
27 if ($option eq 'i' or $option eq 'indep') {
28 push @{$dh{DOPACKAGES}}, getpackages('indep');
31 elsif ($option eq 'a' or $option eq 'arch') {
32 push @{$dh{DOPACKAGES}}, getpackages('arch');
35 elsif ($option eq 'p' or $option eq 'package') {
36 push @{$dh{DOPACKAGES}}, $value;
38 elsif ($option eq 's' or $option eq 'same-arch') {
39 push @{$dh{DOPACKAGES}}, getpackages('same');
43 error("bad option $option - should never happen!\n");
47 # Adds packages to the list of debug packages.
48 sub AddDebugPackage { my($option,$value)=@_;
49 push @{$dh{DEBUGPACKAGES}}, $value;
52 # Add a package to a list of packages that should not be acted on.
53 sub ExcludePackage { my($option,$value)=@_;
54 $exclude_package{$value}=1;
57 # Add another item to the exclude list.
58 sub AddExclude { my($option,$value)=@_;
59 push @{$dh{EXCLUDE}},$value;
62 # Add a file to the ignore list.
63 sub AddIgnore { my($option,$file)=@_;
64 $dh{IGNORE}->{$file}=1;
67 # This collects non-options values.
69 push @{$dh{ARGV}}, @_;
74 my %options=%{shift()} if ref $_[0];
76 Getopt::Long::GetOptionsFromArray($array,
78 "verbose" => \$dh{VERBOSE},
80 "no-act" => \$dh{NO_ACT},
83 "indep" => \&AddPackage,
86 "arch" => \&AddPackage,
88 "p=s" => \&AddPackage,
89 "package=s" => \&AddPackage,
91 "N=s" => \&ExcludePackage,
92 "no-package=s" => \&ExcludePackage,
94 "dbg-package=s" => \&AddDebugPackage,
97 "same-arch" => \&AddPackage,
99 "n" => \$dh{NOSCRIPTS},
100 "noscripts" => \$dh{NOSCRIPTS},
101 "o" => \$dh{ONLYSCRIPTS},
102 "onlyscripts" => \$dh{ONLYSCRIPTS},
104 "X=s" => \&AddExclude,
105 "exclude=s" => \&AddExclude,
110 "keep" => \$dh{K_FLAG},
112 "P=s" => \$dh{TMPDIR},
113 "tmpdir=s" => \$dh{TMPDIR},
115 "u=s", => \$dh{U_PARAMS},
117 "V:s", => \$dh{V_FLAG},
119 "A" => \$dh{PARAMS_ALL},
120 "all" => \$dh{PARAMS_ALL},
122 "sourcedir=s" => \$dh{SOURCEDIR},
124 "destdir=s" => \$dh{DESTDIR},
126 "priority=s" => \$dh{PRIORITY},
128 "h|help" => \&showhelp,
130 "mainpackage=s" => \$dh{MAINPACKAGE},
132 "name=s" => \$dh{NAME},
134 "error-handler=s" => \$dh{ERROR_HANDLER},
136 "ignore=s" => \&AddIgnore,
144 # Parse options and set %dh values.
148 # DH_OPTIONS can contain additional options
149 # to be parsed like @ARGV, but with unknown options
152 if (defined $ENV{DH_OPTIONS}) {
153 $ENV{DH_OPTIONS}=~s/^\s+//;
154 $ENV{DH_OPTIONS}=~s/\s+$//;
155 @ARGV_extra=split(/\s+/,$ENV{DH_OPTIONS});
156 my $ret=getoptions(\@ARGV_extra, $options);
158 warning("warning: ignored unknown options in DH_OPTIONS");
162 # DH_INTERNAL_OPTIONS is used to pass additional options from
163 # dh through an override target to a command.
164 if (defined $ENV{DH_INTERNAL_OPTIONS}) {
165 $ENV{DH_INTERNAL_OPTIONS}=~s/^\s+//;
166 $ENV{DH_INTERNAL_OPTIONS}=~s/\s+$//;
167 unshift @ARGV, split(/\s+/,$ENV{DH_INTERNAL_OPTIONS});
170 my $ret=getoptions(\@ARGV, $options);
172 warning("warning: unknown options will be a fatal error in a future debhelper release");
173 #error("unknown option; aborting");
176 # Check to see if -V was specified. If so, but no parameters were
177 # passed, the variable will be defined but empty.
178 if (defined($dh{V_FLAG})) {
182 # If we have not been given any packages to act on, assume they
183 # want us to act on them all. Note we have to do this before excluding
184 # packages out, below.
185 if (! defined $dh{DOPACKAGES} || ! @{$dh{DOPACKAGES}}) {
186 if ($dh{DOINDEP} || $dh{DOARCH} || $dh{DOSAME}) {
187 # User specified that all arch (in)dep package be
188 # built, and there are none of that type.
189 warning("I have no package to build");
192 push @{$dh{DOPACKAGES}},getpackages();
195 # Remove excluded packages from the list of packages to act on.
196 # Also unique the list, in case some options were specified that
197 # added a package to it twice.
201 foreach $package (@{$dh{DOPACKAGES}}) {
202 if (! $exclude_package{$package}) {
203 if (! exists $packages_seen{$package}) {
204 $packages_seen{$package}=1;
205 push @package_list, $package;
209 @{$dh{DOPACKAGES}}=@package_list;
211 # If there are no packages to act on now, it's an error.
212 if (! defined $dh{DOPACKAGES} || ! @{$dh{DOPACKAGES}}) {
213 error("I have no package to build");
216 if (defined $dh{U_PARAMS}) {
217 # Split the U_PARAMS up into an array.
220 push @{$dh{U_PARAMS}}, split(/\s+/,$u);
223 # Anything left in @ARGV is options that appeared after a --
224 # These options are added to the U_PARAMS array, while the
225 # non-option values we collected replace them in @ARGV;
226 push @{$dh{U_PARAMS}}, @ARGV, @ARGV_extra;
227 @ARGV=@{$dh{ARGV}} if exists $dh{ARGV};
231 # Enable bundling of short command line options.
232 Getopt::Long::config("bundling");