]> git.saurik.com Git - bison.git/blob - build-aux/cross-options.pl
58772775372fd17dcb8e2c0b3d41aa4b2d9517e8
[bison.git] / build-aux / cross-options.pl
1 #! /usr/bin/env perl
2
3 use warnings;
4 use 5.005;
5 use strict;
6
7 my %option;
8 while (<>)
9 {
10 if (/^\s* # Initial spaces.
11 (?:(-\w),\s+)? # $1: $short: Possible short option.
12 (--[-\w]+) # $2: $long: Long option.
13 (\[?) # $3: $opt: '[' iff the argument is optional.
14 (?:=(\S+))? # $4: $arg: Possible argument name.
15 \s # Spaces.
16 /x)
17 {
18 my ($short, $long, $opt, $arg) = ($1, $2, $3, $4);
19 $short = defined $short ? '@option{' . $short . '}' : '';
20 if ($arg)
21 {
22 # if $opt, $arg contains the closing ].
23 substr ($arg, -1) = ''
24 if $opt eq '[';
25 $arg =~ s/^=//;
26 $arg = lc ($arg);
27 # If the argument is compite (e.g., for --define[=NAME[=VALUE]]),
28 # put each word in @var, to build @var{name}[=@var{value}], not
29 # @var{name[=value]}].
30 $arg =~ s/(\w+)/\@var{$1}/g;
31 my $long_arg = "=$arg";
32 if ($opt eq '[') {
33 $long_arg = "[$long_arg]";
34 $arg = "[$arg]";
35 }
36 $option{"$long$long_arg"} = $short ? "$short $arg" : '';
37 }
38 else
39 {
40 $option{"$long"} = "$short";
41 }
42 }
43 }
44
45 foreach my $long (sort keys %option)
46 {
47 # Avoid trailing spaces.
48 printf ("\@item %-40s \@tab%s\n",
49 '@option{' . $long . '}',
50 $option{$long} ? " $option{$long}" : "");
51 }