diff options
-rw-r--r-- | MANIFEST | 19 | ||||
-rwxr-xr-x | Makefile.SH | 64 | ||||
-rw-r--r-- | Porting/exec-bit.txt | 1 | ||||
-rw-r--r-- | pod/perlutil.pod | 62 | ||||
-rw-r--r-- | t/x2p/find2perl.t | 229 | ||||
-rw-r--r-- | t/x2p/s2p.t | 892 | ||||
-rw-r--r-- | utils.lst | 3 | ||||
-rw-r--r-- | vms/descrip_mms.template | 67 | ||||
-rw-r--r-- | win32/Makefile | 46 | ||||
-rw-r--r-- | win32/makefile.mk | 51 | ||||
-rw-r--r-- | x2p/.gitignore | 7 | ||||
-rw-r--r-- | x2p/EXTERN.h | 21 | ||||
-rw-r--r-- | x2p/INTERN.h | 23 | ||||
-rwxr-xr-x | x2p/Makefile.SH | 178 | ||||
-rw-r--r-- | x2p/a2p.c | 2941 | ||||
-rw-r--r-- | x2p/a2p.h | 462 | ||||
-rw-r--r-- | x2p/a2p.pod | 175 | ||||
-rw-r--r-- | x2p/a2p.y | 432 | ||||
-rw-r--r-- | x2p/a2py.c | 1300 | ||||
-rw-r--r-- | x2p/find2perl.PL | 919 | ||||
-rw-r--r-- | x2p/hash.c | 149 | ||||
-rw-r--r-- | x2p/hash.h | 47 | ||||
-rw-r--r-- | x2p/s2p.PL | 2072 | ||||
-rw-r--r-- | x2p/str.c | 260 | ||||
-rw-r--r-- | x2p/str.h | 41 | ||||
-rw-r--r-- | x2p/util.c | 196 | ||||
-rw-r--r-- | x2p/util.h | 32 | ||||
-rw-r--r-- | x2p/walk.c | 2055 |
28 files changed, 19 insertions, 12725 deletions
@@ -5374,8 +5374,6 @@ t/win32/runenv.t Test if Win* perl honors its env variables t/win32/signal.t Test Win32 signal emulation t/win32/system.t See if system works in Win* t/win32/system_tests Test runner for system.t -t/x2p/find2perl.t Test find2perl -t/x2p/s2p.t See if s2p/psed work uconfig64.sh Configuration script for microperl for LP64 uconfig.h Configuration header for microperl uconfig.sh Configuration script for microperl @@ -5491,21 +5489,4 @@ win32/wince.c WinCE port win32/wince.h WinCE port win32/wincesck.c WinCE port write_buildcustomize.pl Generate lib/buildcustomize.pl -x2p/a2p.c Output of a2p.y run through byacc -x2p/a2p.h Global declarations -x2p/a2p.pod Pod for awk to perl translator -x2p/a2p.y A yacc grammar for awk -x2p/a2py.c Awk compiler, sort of -x2p/EXTERN.h Same as above -x2p/find2perl.PL A find to perl translator -x2p/hash.c Hashes again -x2p/hash.h Public declarations for the above -x2p/INTERN.h Same as above -x2p/Makefile.SH Precursor to Makefile -x2p/s2p.PL Sed to perl translator -x2p/str.c String handling package -x2p/str.h Public declarations for the above -x2p/util.c Utility routines -x2p/util.h Public declarations for the above -x2p/walk.c Parse tree walker XSUB.h Include file for extension subroutines diff --git a/Makefile.SH b/Makefile.SH index 727a76304c..72878530b7 100755 --- a/Makefile.SH +++ b/Makefile.SH @@ -435,7 +435,7 @@ SH_to_target() { echo $@ | sed -e s/\\\.SH//g -e s/_/./g } -SH='Makefile.SH cflags.SH config_h.SH makedepend.SH myconfig.SH runtests.SH pod/Makefile.SH x2p/Makefile.SH' +SH='Makefile.SH cflags.SH config_h.SH makedepend.SH myconfig.SH runtests.SH pod/Makefile.SH' shextract=`SH_to_target $SH` ## In the following dollars and backticks do not need the extra backslash. @@ -589,30 +589,15 @@ perl$(OBJ_EXT): git_version.h case "$usedl$static_cwd" in defineundef) util_deps='$(MINIPERL_EXE) $(CONFIGPM) lib/auto/Cwd/Cwd$(DLSUFFIX) FORCE' - x2p_deps="\$(MINIPERL_EXE) \$(CONFIGPM) \$(dynamic_ext) x2p/$firstmakefile FORCE" ;; definedefine) util_deps='$(PERL_EXE) $(CONFIGPM) FORCE' - x2p_deps="\$(PERL_EXE) \$(CONFIGPM) \$(dynamic_ext) x2p/$firstmakefile FORCE" ;; *) util_deps='$(PERL_EXE) $(CONFIGPM) FORCE' - x2p_deps="\$(PERL_EXE) \$(CONFIGPM) x2p/$firstmakefile FORCE" ;; esac $spitshell >>$Makefile <<!GROK!THIS! -x2p/$firstmakefile: makedepend - cd x2p; \$(MAKE) depend - -translators: $x2p_deps - @echo " "; echo " Making x2p stuff"; cd x2p; \$(LDLIBPTH) \$(MAKE) all - -x2p/s2p: $x2p_deps - cd x2p; \$(LDLIBPTH) \$(MAKE) s2p - -x2p/find2perl: $x2p_deps - cd x2p; \$(LDLIBPTH) \$(MAKE) find2perl - utils/Makefile: \$(MINIPERL_EXE) \$(CONFIGPM) utils/Makefile.PL \$(MINIPERL) -Ilib utils/Makefile.PL @@ -1269,7 +1254,6 @@ _mopup: _tidy: -cd pod; $(LDLIBPTH) $(MAKE) clean -cd utils; $(LDLIBPTH) $(MAKE) clean - -cd x2p; $(LDLIBPTH) $(MAKE) clean -rm -f lib/Config_git.pl git_version.h -@for x in $(DYNALOADER) $(dynamic_ext) $(static_ext) $(nonxs_ext) ; do \ $(MINIPERL) make_ext.pl --target=clean $$x MAKE=$(MAKE) ; \ @@ -1279,7 +1263,6 @@ _cleaner1: -cd os2; rm -f Makefile -cd pod; $(LDLIBPTH) $(MAKE) $(CLEAN) -cd utils; $(LDLIBPTH) $(MAKE) $(CLEAN) - -cd x2p; $(LDLIBPTH) $(MAKE) $(CLEAN) -@if test -f $(MINIPERL_EXE) ; then \ for x in $(DYNALOADER) $(dynamic_ext) $(static_ext) $(nonxs_ext) ; do \ $(MINIPERL) make_ext.pl --target=$(CLEAN) $$x MAKE=$(MAKE) ; \ @@ -1409,15 +1392,14 @@ test_prep_pre: preplibrary utilities $(nonxs_ext) case "$targethost" in '') $spitshell >>$Makefile <<'!NO!SUBS!' test_prep test-prep: test_prep_pre $(MINIPERL_EXE) $(unidatafiles) $(PERL_EXE) \ - $(dynamic_ext) $(TEST_PERL_DLL) runtests x2p/s2p x2p/find2perl \ - $(generated_pods) + $(dynamic_ext) $(TEST_PERL_DLL) runtests $(generated_pods) cd t && (rm -f $(PERL_EXE); $(LNS) ../$(PERL_EXE) $(PERL_EXE)) !NO!SUBS! ;; *) $spitshell >>$Makefile <<!GROK!THIS! test_prep test-prep: test_prep_pre \$(MINIPERL_EXE) \$(unidatafiles) \$(PERL_EXE) \ - \$(dynamic_ext) \$(TEST_PERL_DLL) runtests x2p/s2p x2p/find2perl \ + \$(dynamic_ext) \$(TEST_PERL_DLL) runtests \ \$(generated_pods) $to libperl.* $to t/* @@ -1454,8 +1436,6 @@ test_prep test-prep: test_prep_pre \$(MINIPERL_EXE) \$(unidatafiles) \$(PERL_EXE # --- For Module::Build $to cpan/Module-Build/lib/* $to *.h -# --- For t/x2p/s2p.t - $to x2p # --- For t/TEST $to config.sh # --- For lib/diagnostics.t with -Duseshrplib @@ -1608,44 +1588,6 @@ define) echo "This is an EBCDIC system, checking if any parser files need regenerating." >&2 case "$osname" in os390|posix-bc) - if cd x2p - then - rm -f y.tab.c y.tab.h - case "$osname" in - posix-bc) - # we are using two different yaccs in BS2000 Posix! - byacc a2p.y >/dev/null 2>&1 - ;; - *) # e.g. os390 - yacc a2p.y >/dev/null 2>&1 - ;; - esac - if cmp -s y.tab.c a2p.c - then - rm -f y.tab.c - else - echo "a2p.y -> a2p.c" >&2 - mv -f y.tab.c a2p.c - chmod u+w a2p.c - sed -e 's/fprintf *( *stderr *,/PerlIO_printf(Perl_debug_log,/g' \ - -e 's|^static void __YY_YACC_MAIN.*BS2000.*|/*static main deleted*/|' \ - -e 's/y\.tab/a2p/g' a2p.c >a2p.tmp && mv a2p.tmp a2p.c - xxx="$xxx a2p.c" - fi - # In case somebody yacc -d:ed the a2p.y. - if test -f y.tab.h - then - if cmp -s y.tab.h a2p.h - then - rm -f y.tab.h - else - echo "a2p.h -> a2p.h" >&2 - mv -f y.tab.h a2p.h - xxx="$xxx a2p.h" - fi - fi - cd .. - fi ;; *) echo "'$osname' is an EBCDIC system I don't know that well." >&4 diff --git a/Porting/exec-bit.txt b/Porting/exec-bit.txt index 1dd17baa42..a89d496104 100644 --- a/Porting/exec-bit.txt +++ b/Porting/exec-bit.txt @@ -27,7 +27,6 @@ regen/regcharclass.pl regen/uconfig_h.pl runtests.SH t/TEST -x2p/Makefile.SH Porting/Maintainers.pl Porting/add-package.pl Porting/bisect.pl diff --git a/pod/perlutil.pod b/pod/perlutil.pod index ed73229ffc..4047b42e85 100644 --- a/pod/perlutil.pod +++ b/pod/perlutil.pod @@ -76,56 +76,9 @@ typeset PostScript or text file of the whole lot. =head2 Converters -To help you convert legacy programs to Perl, we've included three -conversion filters: - -=over 3 - -=item L<a2p|a2p> - -F<a2p> converts F<awk> scripts to Perl programs; for example, C<a2p -F:> -on the simple F<awk> script C<{print $2}> will produce a Perl program -based around this code: - - while (<>) { - ($Fld1,$Fld2) = split(/[:\n]/, $_, -1); - print $Fld2; - } - -=item L<s2p|s2p> and L<psed> - -Similarly, F<s2p> converts F<sed> scripts to Perl programs. F<s2p> run -on C<s/foo/bar> will produce a Perl program based around this: - - while (<>) { - chomp; - s/foo/bar/g; - print if $printit; - } - -When invoked as F<psed>, it behaves as a F<sed> implementation, written in -Perl. - -=item L<find2perl|find2perl> - -Finally, F<find2perl> translates C<find> commands to Perl equivalents which -use the L<File::Find|File::Find> module. As an example, -C<find2perl . -user root -perm 4000 -print> produces the following callback -subroutine for C<File::Find>: - - sub wanted { - my ($dev,$ino,$mode,$nlink,$uid,$gid); - (($dev,$ino,$mode,$nlink,$uid,$gid) = lstat($_)) && - $uid == $uid{'root'}) && - (($mode & 0777) == 04000); - print("$name\n"); - } - -=back - -As well as these filters for converting other languages, the -L<pl2pm|pl2pm> utility will help you convert old-style Perl 4 libraries to -new-style Perl5 modules. +To help you convert legacy programs to more modern Perl, the +L<pl2pm|pl2pm> utility will help you convert old-style Perl 4 libraries +to new-style Perl5 modules. =head2 Administration @@ -284,10 +237,9 @@ validate your packlists and even create a tarball from an installed module. L<perldoc|perldoc>, L<pod2man|pod2man>, L<perlpod>, L<pod2html|pod2html>, L<pod2usage|pod2usage>, L<podselect|podselect>, L<podchecker|podchecker>, L<splain|splain>, L<perldiag>, -C<roffitall|roffitall>, L<a2p|a2p>, L<s2p|s2p>, L<find2perl|find2perl>, -L<File::Find|File::Find>, L<pl2pm|pl2pm>, L<perlbug|perlbug>, -L<h2ph|h2ph>, L<c2ph|c2ph>, L<h2xs|h2xs>, L<enc2xs>, L<xsubpp>, -L<cpan>, L<instmodsh>, L<piconv>, L<prove>, -L<corelist>, L<ptar>, L<ptardiff>, L<shasum>, L<zipdetails> +C<roffitall|roffitall>, L<File::Find|File::Find>, L<pl2pm|pl2pm>, +L<perlbug|perlbug>, L<h2ph|h2ph>, L<c2ph|c2ph>, L<h2xs|h2xs>, L<enc2xs>, +L<xsubpp>, L<cpan>, L<instmodsh>, L<piconv>, L<prove>, L<corelist>, L<ptar>, +L<ptardiff>, L<shasum>, L<zipdetails> =cut diff --git a/t/x2p/find2perl.t b/t/x2p/find2perl.t deleted file mode 100644 index f0dfa03929..0000000000 --- a/t/x2p/find2perl.t +++ /dev/null @@ -1,229 +0,0 @@ -#!./perl - -# Based on ideas from x2p/s2p.t -# -# This doesn't currently test -exec etc, just the default -print on -# the platforms below. - -BEGIN { - chdir 't' if -d 't'; - @INC = ( '../lib' ); -} - -use strict; -use warnings; -use File::Path 'remove_tree'; -use File::Spec; -require "./test.pl"; - -# add more platforms if you feel like it, but make sure the -# tests below are portable to the find(1) for any new platform, -# or that they skip on that platform -$^O =~ /^(?:linux|\w+bsd|darwin)$/ - or skip_all("Need something vaguely POSIX"); - -my $VERBOSE = grep $_ eq '-v', @ARGV; - -my $tmpdir = tempfile(); -my $script = tempfile(); -mkdir $tmpdir - or die "Cannot make temp dir $tmpdir: $!"; - -# test file names shouldn't contain any shell special characters, -# and for portability, probably shouldn't contain any high ascii or -# Unicode characters -# -# handling Unicode here would be nice, but I think handling of Unicode -# in perl's file system interfaces (open, unlink, readdir) etc needs to -# be more regular before we can expect interoperability between find2perl -# and a system find(1) -# -# keys for the test file list: -# name - required -# type - type of file to create: -# "f" regular file, "d" directory, "l" link to target, -# "s" symlink to target -# atime, mtime - file times (default now) -# mode - file mode (default per umask) -# content - file content for type f files -# target - target for link for type l and s -# -# I could have simply written code to create all the files, but I think -# this makes the file tree a little more obvious -use constant HOUR => 3600; # an hour in seconds -my @test_files = - ( - { name => "abc" }, - { name => "acc", mtime => time() - HOUR * 48 }, - { name => "ac", content => "x" x 10 }, - { name => "somedir", type => "d" }, - { name => "link", type => "l", target => "abc" }, - { name => "symlink", type => "s", target => "brokenlink" }, - ); -# make some files to search -for my $spec (@test_files) { - my $file = File::Spec->catfile($tmpdir, split '/', $spec->{name}); - my $type = $spec->{type} || "f"; - if ($type eq "f") { - open my $fh, ">", $file - or die "Cannot create test file $file: $!"; - if ($spec->{content}) { - binmode $fh; - print $fh $spec->{content}; - } - close $fh - or die "Cannot close $file: $!"; - } - elsif ($type eq "d") { - mkdir $file - or die "Cannot create test directory $file: $!"; - } - elsif ($type eq "l") { - my $target = File::Spec->catfile($tmpdir, split '/', $spec->{target}); - link $target, $file - or die "Cannot create test link $file: $!"; - } - elsif ($type eq "s") { - my $target = File::Spec->catfile($tmpdir, split '/', $spec->{target}); - symlink $target, $file - or die "Cannot create test symlink $file: $!"; - } - if ($spec->{mode}) { - chmod $spec->{mode}, $file - or die "Cannot set mode of test file $file: $!"; - } - if ($spec->{mtime} || $spec->{atime}) { - # default the times to now, since we just created the files - my $mtime = $spec->{mtime} || time(); - my $atime = $spec->{atime} || time(); - utime $atime, $mtime, $file - or die "Cannot set times of test file $file: $!"; - } -} - -# do we have a vaguely sane find(1)? -# BusyBox find is non-POSIX - it doesn't have -links -my @files = sort `find '$tmpdir' '(' -name 'abc' -o -name 'acc' ')' -a -links +0`; -@files == 2 && $files[0] =~ /\babc\n\z/ && $files[1] =~ /\bacc\n\z/ - or skip_all("doesn't appear to be a sane find(1)"); - -# required keys: -# args - find search spec as an array ref -# optional: -# name - short description of the test (defaults to args) -# expect - an array ref of files expected to be found (skips the find(1) call) -# TODO - why this test is TODO (if it is), if a code reference that is -# called to check if the test is TODO (and why) -# SKIP - return a message for why to skip -my @testcases = - ( - { - name => "all files", - args => [], - }, - { - name => "mapping of *", - args => [ "-name", "a*c" ], - }, - { - args => [ "-type", "d" ], - expect => [ "", "somedir" ], - }, - { - args => [ "-type", "f" ], - }, - { - args => [ "-mtime", "+1" ], - expect => [ "acc" ], - }, - { - args => [ "-mtime", "-1" ], - }, - { - args => [ "-size", "10c" ], - expect => [ "ac" ], - }, - { - args => [ "-links", "2" ], - }, - { - name => "[perl #113054] mapping of ?", - args => [ "-name", "a?c" ], - }, - ); - -plan(tests => 1 + 4 * @testcases); - -my $find2perl = File::Spec->catfile(File::Spec->updir(), "x2p", "find2perl"); -ok (-x $find2perl, "find2perl exists"); -our $TODO; - -for my $test (@testcases) { - SKIP: - { - local $TODO = $test->{TODO}; - $TODO = $TODO->() if ref $TODO; - my $args = $test->{args} - or die "Missing test args"; - my $name = $test->{name} || "@$args"; - - my $skip = $test->{SKIP} && $test->{SKIP}->(); - $skip - and skip($skip, 4); - - my $code = runperl(args => [ $find2perl, $tmpdir, @$args ]); - - ok($code, "$name: run findperl") - or skip("", 3); - - open my $script_fh, ">", $script - or die "Cannot create $script: $!"; - print $script_fh $code; - close $script_fh - or die "Cannot close $script: $!"; - - my $files = runperl(progfile => $script); - - ok(length $files, "$name: run output script") - or skip("", 2); - - my $find_files; - my $source; - if ($test->{expect}) { - $find_files = join "\n", - map { $_ eq "" ? $tmpdir : "$tmpdir/$_" } - @{$test->{expect}}; - $source = "expected"; - # to balance the ok() in the other branch - pass("$name: got files ok"); - } - else { - my $findcmd = "find $tmpdir ". join " ", map "'$_'", @$args; - - # make sure PERL_UNICODE doesn't reinterpret the output of find - use open IN => ':raw'; - $find_files = `$findcmd`; - ok(length $find_files, "$name: run find") - or skip("", 1); - $source = "find"; - } - - # is the order from find (or find2perl) guaranteed? - # assume it isn't - $files = join("\n", sort split /\n/, $files); - $find_files = join("\n", sort split /\n/, $find_files); - - if ($VERBOSE) { - note("script:\n$code"); - note("args:\n@$args"); - note("find2perl:\n$files"); - note("find:\n$find_files"); - } - - is($files, $find_files, "$name: find2perl matches $source"); - } -} - -END { - remove_tree($tmpdir); -} diff --git a/t/x2p/s2p.t b/t/x2p/s2p.t deleted file mode 100644 index 0a0716da0c..0000000000 --- a/t/x2p/s2p.t +++ /dev/null @@ -1,892 +0,0 @@ -#!./perl - -=head1 NAME - -s2p.t - test suite for s2p/psed - -=head1 NOTES - -The general idea is to - - (a) run psed with a sed script and input data to obtain some output - (b) run s2p with a sed script creating a Perl program and then run the - Perl program with the input data, again producing output - -Both final outputs should be identical to the expected output. - -A $testcase{<name>} contains entries (after the comment ### <name> ###): - - - script: the sed script - - input: the key of the input data, stored in $input{<input>} - - expect: the expected output - - datfil: an additional file [ <path>, <data> ] (if required) - -Temporary files are created in the working directory (embedding $$ -in the name), and removed after the test. - -Except for bin2dec (which indeed converts binary to decimal) none of the -sed scripts is doing something useful. - -Author: Wolfgang Laun. - -=cut - -BEGIN { - chdir 't' if -d 't'; - @INC = ( '../lib' ); -} - -use File::Copy; -use File::Spec; -require './test.pl'; - -# BRE extensions -$ENV{PSEDEXTBRE} = '<>wW'; - -our %input = ( - bins => <<'[TheEnd]', -0 -111 -1000 -10001 -[TheEnd] - - text => <<'[TheEnd]', -line 1 -line 2 -line 3 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] - - adr1 => <<'[TheEnd]', -#no autoprint -# This script should be run on itself -/^#__DATA__$/,${ - /^#A$/p - s/^# *[0-9]* *// - /^#\*$/p - /^#\.$/p - /^#\(..\)\(..\)\2\1*$/p - /^#[abc]\{1,\}[def]\{1,\}$/p -} -#__DATA__ -#A -#* -#. -#abxyxy -#abxyxyab -#abxyxyabab -#ad -#abcdef -[TheEnd] -); - - -our %testcase = ( - -### bin2dec ### -'bin2dec' => { - script => <<'[TheEnd]', -# binary -> decimal -s/^[ ]*\([01]\{1,\}\)[ ]*/\1/ -t go -i\ -is not a binary number -d - -# expand binary to Xs -: go -s/^0*// -s/^1/X/ -: expand -s/^\(X\{1,\}\)0/\1\1/ -s/^\(X\{1,\}\)1/\1\1X/ -t expand - -# count Xs in decimal -: count -s/^X/1/ -s/0X/1/ -s/1X/2/ -s/2X/3/ -s/3X/4/ -s/4X/5/ -s/5X/6/ -s/6X/7/ -s/7X/8/ -s/8X/9/ -s/9X/X0/ -t count -s/^$/0/ -[TheEnd] - input => 'bins', - expect => <<'[TheEnd]', -0 -7 -8 -17 -[TheEnd] -}, - - -### = ### -'=' => { - script => <<'[TheEnd]', -1= -$= -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -1 -line 1 -line 2 -line 3 -line 4 -line 5 -line 6 -line 7 -8 -line 8 -[TheEnd] -}, - -### D ### -'D' => { - script => <<'[TheEnd]', -#no autoprint -/1/{ -N -N -N -D -} -p -/2/D -= -p -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 2 -line 3 -line 4 -line 3 -line 4 -4 -line 3 -line 4 -line 5 -5 -line 5 -line 6 -6 -line 6 -line 7 -7 -line 7 -line 8 -8 -line 8 -[TheEnd] -}, - -### H ### -'H' => { - script => <<'[TheEnd]', -#no autoprint -1,$H -$g -$= -$p -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -8 - -line 1 -line 2 -line 3 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### N ### -'N' => { - script => <<'[TheEnd]', -3a\ -added line -4a\ -added line -5a\ -added line -3,5N -= -d -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -1 -2 -added line -4 -added line -6 -7 -8 -[TheEnd] -}, - -### P ### -'P' => { - script => <<'[TheEnd]', -1N -2N -3N -4= -4P -4,$d -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -4 -line 1 -[TheEnd] -}, - -### a ### -'a' => { - script => <<'[TheEnd]', -1a\ -added line 1.1\ -added line 1.2 - -3a\ -added line 3.1 -3a\ -added line 3.2 - -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -added line 1.1 -added line 1.2 -line 2 -line 3 -added line 3.1 -added line 3.2 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### b ### -'b' => { - script => <<'[TheEnd]', -#no autoprint -2 b eos -4 b eos -p -: eos -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 3 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### block ### -'block' => { - script => "#no autoprint\n1,3{\n=\np\n}", - input => 'text', - expect => <<'[TheEnd]', -1 -line 1 -2 -line 2 -3 -line 3 -[TheEnd] -}, - -### c ### -'c' => { - script => <<'[TheEnd]', -2= - -2,4c\ -change 2,4 line 1\ -change 2,4 line 2 - -2= - -3,5c\ -change 3,5 line 1\ -change 3,5 line 2 - -3= - -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -2 -change 2,4 line 1 -change 2,4 line 2 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### c1 ### -'c1' => { - script => <<'[TheEnd]', -1c\ -replaces line 1 - -2,3c\ -replaces lines 2-3 - -/5/,/6/c\ -replaces lines 3-4 - -8,10c\ -replaces lines 6-10 -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -replaces line 1 -replaces lines 2-3 -line 4 -replaces lines 3-4 -line 7 -[TheEnd] -}, - -### c2 ### -'c2' => { - script => <<'[TheEnd]', -3!c\ -replace all except line 3 - -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -replace all except line 3 -replace all except line 3 -line 3 -replace all except line 3 -replace all except line 3 -replace all except line 3 -replace all except line 3 -replace all except line 3 -[TheEnd] -}, - -### c3 ### -'c3' => { - script => <<'[TheEnd]', -1,4!c\ -replace all except 1-4 - -/5/,/8/!c\ -replace all except 5-8 -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -replace all except 5-8 -replace all except 5-8 -replace all except 5-8 -replace all except 5-8 -replace all except 1-4 -replace all except 1-4 -replace all except 1-4 -replace all except 1-4 -[TheEnd] -}, - -### d ### -'d' => { - script => <<'[TheEnd]', -# d delete pattern space, start next cycle -2,4 d -5 d -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### gh ### -'gh' => { - script => <<'[TheEnd]', -1h -2g -3h -4g -5q -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 1 -line 3 -line 3 -line 5 -[TheEnd] -}, - -### i ### -'i' => { - script => <<'[TheEnd]', -1i\ -inserted line 1.1\ -inserted line 1.2 - -3i\ -inserted line 3.1 -3i\ -inserted line 3.2 -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -inserted line 1.1 -inserted line 1.2 -line 1 -line 2 -inserted line 3.1 -inserted line 3.2 -line 3 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### n ### -'n' => { - script => <<'[TheEnd]', -3a\ -added line -4a\ -added line -5a\ -added line -3,5n -= -d -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -1 -2 -line 3 -added line -4 -line 5 -added line -6 -7 -8 -[TheEnd] -}, - -### o ### -'o' => { - script => <<'[TheEnd]', -/abc/,/def/ s//XXX/ -// i\ -cheers -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 2 -line 3 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### q ### -'q' => { - script => <<'[TheEnd]', -2a\ -append to line 2 -3a\ -append to line 3 - should not appear in output -3q -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 2 -append to line 2 -line 3 -[TheEnd] -}, - -### r ### -'r' => { - datfil => [ 'r.txt', "r.txt line 1\nr.txt line 2\nr.txt line 3\n" ], - script => <<'[TheEnd]', -2r%r.txt% -4r %r.txt% -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 2 -r.txt line 1 -r.txt line 2 -r.txt line 3 -line 3 -line 4 -r.txt line 1 -r.txt line 2 -r.txt line 3 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### s ### -'s' => { - script => <<'[TheEnd]', -# enclose any '(a)'.. '(c)' in '-' -s/([a-z])/-\1-/g - -s/\([abc]\)/-\1-/g -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 2 -line 3 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### s1 ### -'s1' => { - script => <<'[TheEnd]', -s/\w/@1/ -s/\y/@2/ - -s/\n/@3/ - -# this is literal { } -s/a{3}/@4/ - -# proper repetition -s/a\{3\}/a rep 3/ -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -@1ine 1 -@1ine 2 -@1ine 3 -@1ine 4 -@1ine 5 -@1ine 6 -@1ine 7 -@1ine 8 -[TheEnd] -}, - -### s2 ### RT #115156 -'s2' => { - todo => 'RT #115156', - script => 's/1*$/x/g', - input => 'bins', - expect => <<'[TheEnd]', -0x -x -1000x -1000x -[TheEnd] -}, - -### t ### -'t' => { - script => join( "\n", - '#no autoprint', 's/./X/p', 's/foo/bar/p', 't bye', '=', 'p', ':bye' ), - input => 'text', - expect => <<'[TheEnd]', -Xine 1 -Xine 2 -Xine 3 -Xine 4 -Xine 5 -Xine 6 -Xine 7 -Xine 8 -[TheEnd] -}, - -### w ### -'w' => { - datfil => [ 'w.txt', '' ], - script => <<'[TheEnd]', -w %w.txt% -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 2 -line 3 -line 4 -line 5 -line 6 -line 7 -line 8 -[TheEnd] -}, - -### x ### -'x' => { - script => <<'[TheEnd]', -1h -1d -2x -2,$G -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -line 1 -line 2 -line 3 -line 2 -line 4 -line 2 -line 5 -line 2 -line 6 -line 2 -line 7 -line 2 -line 8 -line 2 -[TheEnd] -}, - -### y ### -'y' => { - script => <<'[TheEnd]', -y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/ -y/|/\ -/ -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -LINE 1 -LINE 2 -LINE 3 -LINE 4 -LINE 5 -LINE 6 -LINE 7 -LINE 8 -[TheEnd] -}, - -### cnt ### -'cnt' => { - script => <<'[TheEnd]', -#no autoprint - -# delete line, append NL to hold space -s/.*// -H -$!b - -# last line only: get hold -g -s/./X/g -t count -: count -s/^X/1/ -s/0X/1/ -s/1X/2/ -s/2X/3/ -s/3X/4/ -s/4X/5/ -s/5X/6/ -s/6X/7/ -s/7X/8/ -s/8X/9/ -s/9X/X0/ -t count -p -[TheEnd] - input => 'text', - expect => <<'[TheEnd]', -8 -[TheEnd] -}, - -### adr1 ### -'adr1' => { - script => <<'[TheEnd]', -#no autoprint -# This script should be run on itself -/^#__DATA__$/,${ - /^#A$/p - s/^# *[0-9]* *// - /^#\*$/p - /^#\.$/p - /^#\(..\)\(..\)\2\1*$/p - /^#[abc]\{1,\}[def]\{1,\}$/p -} -#__DATA__ -#A -#* -#. -#abxyxy -#abxyxyab -#abxyxyabab -#ad -#abcdef -[TheEnd] - input => 'adr1', - expect => <<'[TheEnd]', -#A -[TheEnd] -}, - -); - -my @aux = (); -my $ntc = 2 * keys %testcase; -plan( $ntc ); - -# temporary file names -my $script = "s2pt$$.sed"; -my $stdin = "s2pt$$.in"; -my $plsed = "s2pt$$.pl"; - -# various command lines for -my $s2p = File::Spec->catfile( File::Spec->updir(), 'x2p', 's2p' ); -my $psed = File::Spec->catfile( File::Spec->curdir(), 'psed' ); -if ($^O eq 'VMS') { - # default in the .com extension if it's not already there - $s2p = VMS::Filespec::vmsify($s2p); - $psed = VMS::Filespec::vmsify($psed); - # Converting file specs from Unix format to VMS with the extended - # character set active can result in a trailing '.' added for null - # extensions. This must be removed if the intent is to default the - # extension. - $s2p =~ s/\.$//; - $psed =~ s/\.$//; - $s2p = VMS::Filespec::rmsexpand($s2p, '.com'); - $psed = VMS::Filespec::rmsexpand($psed, '.com'); -} -my $sedcmd = [ $psed, '-f', $script, $stdin ]; -my $s2pcmd = [ $s2p, '-f', $script ]; -my $plcmd = [ $plsed, $stdin ]; - -# psed: we create a local copy as linking may not work on some systems. -copy( $s2p, $psed ); -push( @aux, $psed ); - -# process all testcases -# -my $indat = ''; -for my $tc ( sort keys %testcase ){ - my( $psedres, $s2pres ); - - local $TODO = $testcase{$tc}{todo}; - - # 1st test: run psed - # prepare the script - open( SED, ">$script" ) || goto FAIL_BOTH; - my $script = $testcase{$tc}{script}; - - # additional files for r, w: patch script, inserting temporary names - if( exists( $testcase{$tc}{datfil} ) ){ - my( $datnam, $datdat ) = @{$testcase{$tc}{datfil}}; - my $datfil = "s2pt$$" . $datnam; - push( @aux, $datfil ); - open( DAT, ">$datfil" ) || goto FAIL_BOTH; - print DAT $datdat; - close( DAT ); - $script =~ s/\%$datnam\%/$datfil/eg; - } - print SED $script; - close( SED ) || goto FAIL_BOTH; - - # prepare input - # - if( $indat ne $testcase{$tc}{input} ){ - $indat = $testcase{$tc}{input}; - open( IN, ">$stdin" ) || goto FAIL_BOTH; - print IN $input{$indat}; - close( IN ) || goto FAIL_BOTH; - } - - # on VMS, runperl eats blank lines to work around - # spurious newlines in pipes - $testcase{$tc}{expect} =~ s/\n\n/\n/ if $^O eq 'VMS'; - - # run and compare - # - $psedres = runperl( args => $sedcmd ); - is( $psedres, $testcase{$tc}{expect}, "psed $tc" ); - - # 2nd test: run s2p - # translate the sed script to a Perl program - - my $perlprog = runperl( args => $s2pcmd ); - open( PP, ">$plsed" ) || goto FAIL_S2P; - print PP $perlprog; - close( PP ) || goto FAIL_S2P; - - # execute generated Perl program, compare - $s2pres = runperl( args => $plcmd ); - is( $s2pres, $testcase{$tc}{expect}, "s2p $tc" ); - next; - -FAIL_BOTH: - fail( "psed $tc" ); -FAIL_S2P: - fail( "s2p $tc" ); -} - -END { - for my $f ( $script, $stdin, $plsed, @aux ){ - 1 while unlink( $f ); # hats off to VMS... - } -} @@ -26,6 +26,3 @@ utils/shasum utils/splain utils/xsubpp utils/zipdetails -x2p/a2p -x2p/find2perl -x2p/s2p # link = x2p/psed diff --git a/vms/descrip_mms.template b/vms/descrip_mms.template index ff5f82b766..3398e91ea3 100644 --- a/vms/descrip_mms.template +++ b/vms/descrip_mms.template @@ -166,11 +166,9 @@ MTHREADLINKFLAGS = # C preprocessor manifest "DEBUGGING" ==> perl -D, not the VMS debugger .IFDEF LARGEFILE CFLAGS = $(XTRACCFLAGS)$(DBGCCFLAGS)$(FLAGS)/Define=$(LARGEFILE) -X2PCFLAGS = $(XTRACCFLAGS)$(DBGCCFLAGS)$(FLAGS)/Define=(PERL_FOR_X2P,$(LARGEFILE)) CORECFLAGS = $(XTRACCFLAGS)$(DBGCCFLAGS)$(FLAGS)/Define=(PERL_CORE,$(LARGEFILE)) .ELSE CFLAGS = $(XTRACCFLAGS)$(DBGCCFLAGS)$(FLAGS) -X2PCFLAGS = $(XTRACCFLAGS)$(DBGCCFLAGS)$(FLAGS)/Define=PERL_FOR_X2P CORECFLAGS = $(XTRACCFLAGS)$(DBGCCFLAGS)$(FLAGS)/Define=PERL_CORE .ENDIF @@ -289,19 +287,11 @@ utils3 = [.utils]perlivp.com [.lib]splain.com [.utils]pl2pm.com [.utils]xsubpp.c utils4 = [.utils]enc2xs.com [.utils]piconv.com [.utils]cpan.com [.utils]prove.com [.utils]ptar.com [.utils]ptardiff.com [.utils]shasum.com utils5 = [.utils]corelist.com [.utils]ptargrep.com [.utils]zipdetails.com -.ifdef NOX2P all : base extras archcorefiles preplibrary [.pod]perltoc.pod @ QUALIFIERS := $(MMSQUALIFIERS) @ QUALIFIERS = QUALIFIERS - """" - """" @ write sys$output " " @ write sys$output " Everything is up to date. '$(MMS)''QUALIFIERS' test' to run test suite." -.else -all : base extras x2p archcorefiles preplibrary [.pod]perltoc.pod - @ QUALIFIERS := $(MMSQUALIFIERS) - @ QUALIFIERS = QUALIFIERS - """" - """" - @ write sys$output " " - @ write sys$output " Everything is up to date. '$(MMS)''QUALIFIERS' test' to run test suite." -.endif git_version.h : $(MINIPERL_EXE) make_patchnum.pl $(MINIPERL) make_patchnum.pl @@ -314,8 +304,6 @@ libmods : $(LIBPREREQ) @ $(NOOP) utils : $(utils1) $(utils2) $(utils3) $(utils4) $(utils5) @ $(NOOP) -x2p : [.x2p]$(DBG)a2p$(E) [.x2p]s2p.com [.x2p]find2perl.com - @ $(NOOP) extra.pods : miniperl @ @extra_pods.com @@ -511,12 +499,6 @@ nonxsext : $(LIBPREREQ) preplibrary $(MINIPERL_EXE) [.pod]perlfunc.pod $(MINIPERL) -"I[-.lib]" $(MMS$SOURCE) Copy/NoConfirm/Log [.utils]splain.com [.lib] -[.x2p]find2perl.com : [.x2p]find2perl.PL $(ARCHDIR)Config.pm - $(MINIPERL) -"I[-.lib]" $(MMS$SOURCE) - -[.x2p]s2p.com : [.x2p]s2p.PL $(ARCHDIR)Config.pm - $(MINIPERL) -"I[-.lib]" $(MMS$SOURCE) - [.utils]xsubpp.com : [.utils]xsubpp.PL $(ARCHDIR)Config.pm nonxsext $(MINIPERL) -"I[-.lib]" $(MMS$SOURCE) @@ -526,35 +508,6 @@ nonxsext : $(LIBPREREQ) preplibrary $(MINIPERL_EXE) [.pod]perlfunc.pod [.utils]pod2html.com : [.utils]pod2html.PL $(ARCHDIR)Config.pm nonxsext $(MINIPERL) -"I[-.lib]" $(MMS$SOURCE) -# Rename catches problem with some DECC versions in which object file is -# placed in current default dir, not same one as source file. -[.x2p]$(DBG)a2p$(E) : [.x2p]a2p$(O), [.x2p]hash$(O), [.x2p]str$(O), [.x2p]util$(O), [.x2p]walk$(O) - @ If F$Search("hash$(O)").nes."" Then Rename/NoLog hash$(O),str$(O),util$(O),walk$(O) [.x2p] - Link $(LINKFLAGS) /Exe=$(MMS$TARGET) $(MMS$SOURCE_LIST) $(CRTLOPTS) - -# Accommodate buggy cpp in some version of DECC, which chokes on illegal -# filespec "y.tab.c", and broken gcc cpp, which doesn't start #include "" -# search in same dir as source file -[.x2p]a2p$(O) : [.x2p]a2p.c [.x2p]a2py.c [.x2p]INTERN.h [.x2p]a2p.h [.x2p]hash.h [.x2p]str.h config.h handy.h vmsish.h $(MINIPERL_EXE) - $(MINIPERL) -pe "s/^#line\s+(\d+)\s+\Q""y.tab.c""/#line $1 ""y_tab.c""/;" $(MMS$SOURCE) >$(MMS$TARGET_NAME)_vms.c - $(CC) $(X2PCFLAGS) /Object=$(MMS$TARGET)/Include=([.x2p],[],"./x2p") $(MMS$TARGET_NAME)_vms.c - Delete/Log/NoConfirm $(MMS$TARGET_NAME)_vms.c; - -# gcc cpp broken -- doesn't look in directory of source file for #include "" -.ifdef GNUC -[.x2p]hash$(O) : [.x2p]hash.c - $(CC) $(X2PCFLAGS) /Include=[.x2p] $(MMS$SOURCE) - -[.x2p]str$(O) : [.x2p]str.c - $(CC) $(X2PCFLAGS) /Include=[.x2p] $(MMS$SOURCE) - -[.x2p]util$(O) : [.x2p]util.c - $(CC) $(X2PCFLAGS) /Include=[.x2p] $(MMS$SOURCE) - -[.x2p]walk$(O) : [.x2p]walk.c - $(CC) $(X2PCFLAGS) /Include=[.x2p] $(MMS$SOURCE) -.endif - preplibrary : $(MINIPERL_EXE) $(LIBPREREQ) @ $(NOOP) @@ -625,8 +578,8 @@ archify : all Delete/Log/NoConfirm [.lib.auto...]*.*;*/exclude=(*.al,*.ix,*.dir) Delete/Log/NoConfirm [.lib]Config.pm;* Delete/Log/NoConfirm [.lib]Config_heavy.pl;* - Copy/Log/NoConfirm *$(E);,[.x2p]$(DBG)a2p$(E); $(ARCHDIR) - Delete/Log/NoConfirm Perl*$(E);*,[.x2p]$(DBG)a2p$(E);* + Copy/Log/NoConfirm *$(E);, $(ARCHDIR) + Delete/Log/NoConfirm Perl*$(E);* @ QUALIFIERS := $(MMSQUALIFIERS) @ QUALIFIERS = QUALIFIERS - """" - """" @ Write Sys$Output "Architecture-specific setup completed." @@ -655,7 +608,7 @@ $(ARCHAUTO)time.stamp : .ifdef LINK_ONLY .else -# We need an action line here for broken older versions of MMS which +# We need(ed?) an action line here for broken older versions of MMS which # otherwise conclude that they should be compiling [.x2p]utils.c :-( #util$(O) : util.c # $(CC) $(CORECFLAGS) $(MMS$SOURCE) @@ -743,18 +696,6 @@ util$(O) : util.c $(h) vms$(O) : vms.c $(h) $(CC) $(CORECFLAGS) $(MMS$SOURCE) -[.x2p]hash$(O) : [.x2p]hash.c [.x2p]EXTERN.h [.x2p]a2p.h [.x2p]hash.h [.x2p]str.h [.x2p]util.h config.h handy.h vmsish.h - $(CC) $(X2PCFLAGS) $(MMS$SOURCE) - -[.x2p]str$(O) : [.x2p]str.c [.x2p]EXTERN.h [.x2p]a2p.h [.x2p]hash.h [.x2p]str.h [.x2p]util.h config.h handy.h vmsish.h - $(CC) $(X2PCFLAGS) $(MMS$SOURCE) - -[.x2p]util$(O) : [.x2p]util.c [.x2p]EXTERN.h [.x2p]INTERN.h [.x2p]a2p.h [.x2p]hash.h [.x2p]str.h [.x2p]util.h config.h handy.h vmsish.h - $(CC) $(X2PCFLAGS) $(MMS$SOURCE) - -[.x2p]walk$(O) : [.x2p]walk.c [.x2p]EXTERN.h [.x2p]a2p.h [.x2p]hash.h [.x2p]str.h [.x2p]util.h config.h handy.h vmsish.h - $(CC) $(X2PCFLAGS) $(MMS$SOURCE) - # End of automatically generated make dependencies .endif # !LINK_ONLY @@ -819,7 +760,6 @@ tidy : cleanlis - If F$Search("[.lib]*.com;-1").nes."" Then Purge/NoConfirm/Log [.lib]*.com - If F$Search("[.pod]*.com;-1").nes."" Then Purge/NoConfirm/Log [.pod]*.com - If F$Search("[.utils]*.com;-1").nes."" Then Purge/NoConfirm/Log [.utils]*.com - - If F$Search("[.x2p]*.com;-1").nes."" Then Purge/NoConfirm/Log [.x2p]*.com - If F$Search("[.lib]buildcustomize.pl;-1").nes."" Then Purge/NoConfirm/Log [.lib]buildcustomize.pl clean : tidy cleantest @@ -869,7 +809,6 @@ realclean : clean - If F$Search("[.lib...].exists").nes."" Then Delete/NoConfirm/Log [.lib...].exists;* - If F$Search("[.pod]*.com").nes."" Then Delete/NoConfirm/Log [.pod]*.com;* - If F$Search("[.utils]*.com").nes."" Then Delete/NoConfirm/Log [.utils]*.com;* - - If F$Search("[.x2p]*.com").nes."" Then Delete/NoConfirm/Log [.x2p]*.com;* - If F$Search("$(ARCHDIR)Config.pm").nes."" Then Delete/NoConfirm/Log $(ARCHDIR)Config.pm;* - If F$Search("$(ARCHDIR)Config_heavy.pl").nes."" Then Delete/NoConfirm/Log $(ARCHDIR)Config_heavy.pl;* - If F$Search("[.utils]perldoc.com").nes."" Then Delete/NoConfirm/Log [.utils]perldoc.com;* diff --git a/win32/Makefile b/win32/Makefile index 9979998dbb..383bee7f01 100644 --- a/win32/Makefile +++ b/win32/Makefile @@ -581,7 +581,6 @@ WPERLEXE = ..\wperl.exe PERLEXESTATIC = ..\perl-static.exe GLOBEXE = ..\perlglob.exe CONFIGPM = ..\lib\Config.pm ..\lib\Config_heavy.pl -X2P = ..\x2p\a2p.exe GENUUDMAP = ..\generate_uudmap.exe !IF "$(BUILD_STATIC)" == "define" || "$(ALL_STATIC)" == "define" PERLSTATIC = static @@ -640,9 +639,6 @@ UTILS = \ ..\utils\instmodsh \ ..\utils\json_pp \ ..\utils\pod2html \ - ..\x2p\find2perl \ - ..\x2p\psed \ - ..\x2p\s2p \ bin\exetype.pl \ bin\runperl.pl \ bin\pl2bat.pl \ @@ -722,13 +718,6 @@ WIN32_SRC = $(WIN32_SRC) .\win32io.c #!ENDIF -X2P_SRC = \ - ..\x2p\a2p.c \ - ..\x2p\hash.c \ - ..\x2p\str.c \ - ..\x2p\util.c \ - ..\x2p\walk.c - CORE_NOCFG_H = \ ..\av.h \ ..\cop.h \ @@ -786,7 +775,6 @@ MINICORE_OBJ = $(MICROCORE_OBJ:..\=.\mini\) \ MINIWIN32_OBJ = $(WIN32_OBJ:.\=.\mini\) MINI_OBJ = $(MINICORE_OBJ) $(MINIWIN32_OBJ) DLL_OBJ = $(DYNALOADER) -X2P_OBJ = $(X2P_SRC:.c=.obj) GENUUDMAP_OBJ = $(GENUUDMAP:.exe=.obj) PERLDLL_OBJ = $(CORE_OBJ) @@ -845,7 +833,7 @@ CFG_VARS = \ # all : .\config.h ..\git_version.h $(GLOBEXE) $(CONFIGPM) \ - $(UNIDATAFILES) MakePPPort $(PERLEXE) $(X2P) Extensions_nonxs Extensions $(PERLSTATIC) + $(UNIDATAFILES) MakePPPort $(PERLEXE) Extensions_nonxs Extensions $(PERLSTATIC) @echo Everything is up to date. '$(MAKE_BARE) test' to run test suite. regnodes : ..\regnodes.h @@ -855,7 +843,7 @@ regnodes : ..\regnodes.h ..\regexec$(o) : ..\regnodes.h ..\regcharclass.h reonly : regnodes .\config.h ..\git_version.h $(GLOBEXE) $(CONFIGPM) \ - $(UNIDATAFILES) $(PERLEXE) $(X2P) Extensions_reonly + $(UNIDATAFILES) $(PERLEXE) Extensions_reonly @echo Perl and 're' are up to date. static: $(PERLEXESTATIC) @@ -1024,7 +1012,6 @@ $(MINI_OBJ) : $(CORE_NOCFG_H) $(WIN32_OBJ) : $(CORE_H) $(CORE_OBJ) : $(CORE_H) $(DLL_OBJ) : $(CORE_H) -$(X2P_OBJ) : $(CORE_H) perldll.def : $(MINIPERL) $(CONFIGPM) ..\embed.fnc ..\makedef.pl create_perllibst_h.pl $(MINIPERL) -I..\lib create_perllibst_h.pl @@ -1046,29 +1033,6 @@ $(PERLSTATICLIB): Extensions_static $(PERLEXE_RES): perlexe.rc $(PERLEXE_MANIFEST) $(PERLEXE_ICO) -..\x2p\a2p$(o) : ..\x2p\a2p.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\a2p.c - -..\x2p\hash$(o) : ..\x2p\hash.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\hash.c - -..\x2p\str$(o) : ..\x2p\str.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\str.c - -..\x2p\util$(o) : ..\x2p\util.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\util.c - -..\x2p\walk$(o) : ..\x2p\walk.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\walk.c - -$(X2P) : $(MINIPERL) $(X2P_OBJ) Extensions - $(MINIPERL) -I..\lib ..\x2p\find2perl.PL - $(MINIPERL) -I..\lib ..\x2p\s2p.PL - $(LINK32) -subsystem:console -out:$@ @<< - $(LINK_FLAGS) $(LIBFILES) $(X2P_OBJ) -<< - $(EMBED_EXE_MANI) - $(MINIDIR)\globals$(o) : $(GENERATED_HEADERS) $(UUDMAP_H) $(MG_DATA_H) : $(BITCOUNT_H) @@ -1154,7 +1118,7 @@ doc: $(PERLEXE) ..\pod\perltoc.pod # Note that this next section is parsed (and regenerated) by pod/buildtoc # so please check that script before making structural changes here -utils: $(PERLEXE) $(X2P) ..\utils\Makefile +utils: $(PERLEXE) ..\utils\Makefile cd ..\utils $(MAKE) PERL=$(MINIPERL) cd ..\pod @@ -1299,7 +1263,6 @@ distclean: realclean -cd ..\utils && del /f h2ph splain perlbug pl2pm c2ph pstruct h2xs \ perldoc perlivp libnetcfg enc2xs piconv cpan *.bat \ xsubpp pod2html instmodsh json_pp prove ptar ptardiff ptargrep shasum corelist zipdetails - -cd ..\x2p && del /f find2perl s2p psed *.bat -del /f ..\config.sh perlmain.c dlutils.c config.h.new \ perlmainst.c -del /f $(CONFIGPM) @@ -1326,7 +1289,6 @@ installbare : utils ..\pod\perltoc.pod if exist $(PERLEXESTATIC) $(XCOPY) $(PERLEXESTATIC) $(INST_BIN)\*.* $(XCOPY) $(GLOBEXE) $(INST_BIN)\*.* if exist ..\perl*.pdb $(XCOPY) ..\perl*.pdb $(INST_BIN)\*.* - if exist ..\x2p\a2p.pdb $(XCOPY) ..\x2p\a2p.pdb $(INST_BIN)\*.* $(XCOPY) bin\*.bat $(INST_SCRIPT)\*.* installhtml : doc @@ -1414,10 +1376,8 @@ _clean : -@$(DEL) $(UNIDATAFILES) -@$(DEL) $(WIN32_OBJ) -@$(DEL) $(DLL_OBJ) - -@$(DEL) $(X2P_OBJ) -@$(DEL) ..\*$(o) ..\*.lib ..\*.exp *$(o) *.lib *.exp *.res -@$(DEL) ..\t\*.exe ..\t\*.dll ..\t\*.bat - -@$(DEL) ..\x2p\*.exe ..\x2p\*.bat -@$(DEL) *.ilk -@$(DEL) *.pdb -@$(DEL) Extensions_static diff --git a/win32/makefile.mk b/win32/makefile.mk index 6aeef745be..b0f54d7061 100644 --- a/win32/makefile.mk +++ b/win32/makefile.mk @@ -692,7 +692,6 @@ PERLEXESTATIC = ..\perl-static.exe STATICDIR = .\static.tmp GLOBEXE = ..\perlglob.exe CONFIGPM = ..\lib\Config.pm ..\lib\Config_heavy.pl -X2P = ..\x2p\a2p.exe GENUUDMAP = ..\generate_uudmap.exe .IF "$(BUILD_STATIC)" == "define" || "$(ALL_STATIC)" == "define" PERLSTATIC = static @@ -749,9 +748,6 @@ UTILS = \ ..\utils\shasum \ ..\utils\instmodsh \ ..\utils\json_pp \ - ..\x2p\find2perl \ - ..\x2p\psed \ - ..\x2p\s2p \ bin\exetype.pl \ bin\runperl.pl \ bin\pl2bat.pl \ @@ -845,13 +841,6 @@ WIN32_SRC = \ WIN32_SRC += .\win32io.c #.ENDIF -X2P_SRC = \ - ..\x2p\a2p.c \ - ..\x2p\hash.c \ - ..\x2p\str.c \ - ..\x2p\util.c \ - ..\x2p\walk.c - CORE_NOCFG_H = \ ..\av.h \ ..\cop.h \ @@ -907,7 +896,6 @@ MINICORE_OBJ = $(MINIDIR)\{$(MICROCORE_OBJ:f) miniperlmain$(o) perlio$(o)} MINIWIN32_OBJ = $(MINIDIR)\{$(WIN32_OBJ:f)} MINI_OBJ = $(MINICORE_OBJ) $(MINIWIN32_OBJ) DLL_OBJ = $(DYNALOADER) -X2P_OBJ = $(X2P_SRC:db:+$(o)) GENUUDMAP_OBJ = $(GENUUDMAP:db:+$(o)) PERLDLL_OBJ = $(CORE_OBJ) @@ -976,7 +964,7 @@ CFG_VARS = \ all : CHECKDMAKE .\config.h ..\git_version.h $(GLOBEXE) $(MINIPERL) \ $(CONFIGPM) $(UNIDATAFILES) MakePPPort \ - $(PERLEXE) $(X2P) Extensions Extensions_nonxs $(PERLSTATIC) + $(PERLEXE) Extensions Extensions_nonxs $(PERLSTATIC) regnodes : ..\regnodes.h @@ -986,7 +974,7 @@ regnodes : ..\regnodes.h reonly : regnodes .\config.h ..\git_version.h $(GLOBEXE) $(MINIPERL) \ $(CONFIGPM) $(UNIDATAFILES) $(PERLEXE) \ - $(X2P) Extensions_reonly + Extensions_reonly static: $(PERLEXESTATIC) @@ -1181,8 +1169,6 @@ $(CORE_OBJ) : $(CORE_H) $(DLL_OBJ) : $(CORE_H) -$(X2P_OBJ) : $(CORE_H) - perldll.def : $(MINIPERL) $(CONFIGPM) ..\embed.fnc ..\makedef.pl create_perllibst_h.pl $(MINIPERL) -I..\lib create_perllibst_h.pl $(MINIPERL) -I..\lib -w ..\makedef.pl PLATFORM=win32 $(OPTIMIZE) $(DEFINES) \ @@ -1229,33 +1215,6 @@ $(PERLSTATICLIB): $(PERLDLL_OBJ) Extensions_static $(PERLEXE_RES): perlexe.rc $(PERLEXE_MANIFEST) $(PERLEXE_ICO) -..\x2p\a2p$(o) : ..\x2p\a2p.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\a2p.c - -..\x2p\hash$(o) : ..\x2p\hash.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\hash.c - -..\x2p\str$(o) : ..\x2p\str.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\str.c - -..\x2p\util$(o) : ..\x2p\util.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\util.c - -..\x2p\walk$(o) : ..\x2p\walk.c - $(CC) -I..\x2p $(CFLAGS) $(OBJOUT_FLAG)$@ -c ..\x2p\walk.c - -$(X2P) : $(MINIPERL) $(X2P_OBJ) Extensions - $(MINIPERL) -I..\lib ..\x2p\find2perl.PL - $(MINIPERL) -I..\lib ..\x2p\s2p.PL -.IF "$(CCTYPE)" == "GCC" - $(LINK32) -v -o $@ $(BLINK_FLAGS) \ - $(mktmp $(LKPRE) $(X2P_OBJ) $(LIBFILES) $(LKPOST)) -.ELSE - $(LINK32) -subsystem:console -out:$@ $(BLINK_FLAGS) \ - @$(mktmp $(LIBFILES) $(X2P_OBJ)) - $(EMBED_EXE_MANI) -.ENDIF - $(MINIDIR)\globals$(o) : $(GENERATED_HEADERS) $(UUDMAP_H) $(MG_DATA_H) : $(BITCOUNT_H) @@ -1355,7 +1314,7 @@ doc: $(PERLEXE) ..\pod\perltoc.pod # Note that this next section is parsed (and regenerated) by pod/buildtoc # so please check that script before making structural changes here -utils: $(PERLEXE) $(X2P) ..\utils\Makefile +utils: $(PERLEXE) ..\utils\Makefile cd ..\utils && $(MAKE) PERL=$(MINIPERL) copy ..\README.aix ..\pod\perlaix.pod copy ..\README.amiga ..\pod\perlamiga.pod @@ -1497,7 +1456,6 @@ distclean: realclean -cd ..\utils && del /f h2ph splain perlbug pl2pm c2ph pstruct h2xs \ perldoc perlivp libnetcfg enc2xs piconv cpan *.bat \ xsubpp pod2html instmodsh json_pp prove ptar ptardiff ptargrep shasum corelist zipdetails - -cd ..\x2p && del /f find2perl s2p psed *.bat -del /f ..\config.sh perlmain.c dlutils.c config.h.new \ perlmainst.c -del /f $(CONFIGPM) @@ -1524,7 +1482,6 @@ installbare : utils ..\pod\perltoc.pod if exist $(PERLEXESTATIC) $(XCOPY) $(PERLEXESTATIC) $(INST_BIN)\*.* $(XCOPY) $(GLOBEXE) $(INST_BIN)\*.* if exist ..\perl*.pdb $(XCOPY) ..\perl*.pdb $(INST_BIN)\*.* - if exist ..\x2p\a2p.pdb $(XCOPY) ..\x2p\a2p.pdb $(INST_BIN)\*.* $(XCOPY) bin\*.bat $(INST_SCRIPT)\*.* installhtml : doc @@ -1618,10 +1575,8 @@ _clean : -@erase $(UNIDATAFILES) -@erase $(WIN32_OBJ) -@erase $(DLL_OBJ) - -@erase $(X2P_OBJ) -@erase ..\*$(o) ..\*$(a) ..\*.exp *$(o) *$(a) *.exp *.res -@erase ..\t\*.exe ..\t\*.dll ..\t\*.bat - -@erase ..\x2p\*.exe ..\x2p\*.bat -@erase *.ilk -@erase *.pdb -@erase Extensions_static diff --git a/x2p/.gitignore b/x2p/.gitignore deleted file mode 100644 index 1ee0a5b858..0000000000 --- a/x2p/.gitignore +++ /dev/null @@ -1,7 +0,0 @@ -/a2p -/find2perl -/find2perl.bat -/psed -/psed.bat -/s2p -/s2p.bat diff --git a/x2p/EXTERN.h b/x2p/EXTERN.h deleted file mode 100644 index dcc1b24395..0000000000 --- a/x2p/EXTERN.h +++ /dev/null @@ -1,21 +0,0 @@ -/* EXTERN.h - * - * Copyright (C) 1991, 1992, 1993, 1994, by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#undef EXT -#define EXT extern - -#ifdef __cplusplus -# define EXTERN_C extern "C" -#else -# define EXTERN_C extern -#endif - -#undef INIT -#define INIT(x) - -#undef DOINIT diff --git a/x2p/INTERN.h b/x2p/INTERN.h deleted file mode 100644 index 29332945d8..0000000000 --- a/x2p/INTERN.h +++ /dev/null @@ -1,23 +0,0 @@ -/* INTERN.h - * - * Copyright (C) 1993, 1994, by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#undef EXT -#define EXT - -#ifdef __cplusplus -# define EXTERN_C extern "C" -#else -# ifndef EXTERN_C -# define EXTERN_C -# endif -#endif - -#undef INIT -#define INIT(x) = x - -#define DOINIT diff --git a/x2p/Makefile.SH b/x2p/Makefile.SH deleted file mode 100755 index 2e554014c5..0000000000 --- a/x2p/Makefile.SH +++ /dev/null @@ -1,178 +0,0 @@ -#!/bin/sh - -case $PERL_CONFIG_SH in -'') - if test -f config.sh; then TOP=.; - elif test -f ../config.sh; then TOP=..; - elif test -f ../../config.sh; then TOP=../..; - elif test -f ../../../config.sh; then TOP=../../..; - elif test -f ../../../../config.sh; then TOP=../../../..; - else - echo "Can't find config.sh."; exit 1 - fi - . $TOP/config.sh - ;; -esac -: This forces SH files to create target in same directory as SH file. -: This is so that make depend always knows where to find SH derivatives. -case "$0" in -*/Makefile.SH) cd `expr X$0 : 'X\(.*\)/'` ;; -Makefile.SH) ;; -*) case `pwd` in - */x2p) ;; - *) if test -d x2p; then cd x2p - else echo "Can't figure out where to write output."; exit 1 - fi;; - esac;; -esac - -echo "Extracting x2p/Makefile (with variable substitutions)" -rm -f Makefile - -# The .PL extractions use the Cwd extension. For statically-built -# perls, we need perl, not just miniperl. -case "$usedl" in - define) perl="../miniperl" ;; - *) perl="../perl" ;; -esac - -cat >Makefile <<!GROK!THIS! -# $RCSfile: Makefile.SH,v $$Revision: 4.1 $$Date: 92/08/07 18:29:07 $ -# -# $Log: Makefile.SH,v $ - -CC = $cc -BYACC = $byacc -LDFLAGS = $ldflags -shellflags = $shellflags - -libs = $perllibs - -$make_set_make -# grrr -SHELL = $sh - -# These variables may need to be manually set for non-Unix systems. -AR = $ar -EXE_EXT = $_exe -LIB_EXT = $_a -OBJ_EXT = $_o -PATH_SEP = $p_ - -FIRSTMAKEFILE = $firstmakefile - -# how to tr(anslate) newlines - -TRNL = '$trnl' - -OPTIMIZE = $optimize - -.SUFFIXES: .c \$(OBJ_EXT) - -RUN = -PERL = $perl - -!GROK!THIS! - -cat >>Makefile <<'!NO!SUBS!' - -REALPERL = ../perl -CCCMD = `sh $(shellflags) ../cflags "optimize='$(OPTIMIZE)'" $@` - -pl = find2perl.PL s2p.PL -plextract = find2perl s2p - -h = EXTERN.h INTERN.h ../config.h ../handy.h hash.h a2p.h str.h util.h - -c = hash.c str.c util.c walk.c - -obj = hash$(OBJ_EXT) str$(OBJ_EXT) util$(OBJ_EXT) walk$(OBJ_EXT) - -lintflags = -phbvxac - - -.c$(OBJ_EXT): - $(CCCMD) -DPERL_FOR_X2P $*.c - -all: a2p$(EXE_EXT) s2p find2perl - @echo " " - -a2p$(EXE_EXT): $(obj) a2p$(OBJ_EXT) - $(CC) -o a2p $(LDFLAGS) $(obj) a2p$(OBJ_EXT) $(libs) - -# I now supply a2p.c with the kits, so the following section is -# used only if you force byacc to run by saying -# make run_byacc -# byacc 1.8.2 or 1.9 are recommended. - -run_byacc: FORCE - @ echo Expect many shift/reduce and reduce/reduce conflicts - $(BYACC) a2p.y - rm -f a2p.c - sed -e 's/(yyn = yydefred\[yystate\])/((yyn = yydefred[yystate]))/' \ - -e 's/(yys = getenv("YYDEBUG"))/((yys = getenv("YYDEBUG")))/' \ - -e 's/^yyerrlab://' \ - -e 's/^ goto yyerrlab;//' \ - -e 's/^yynewerror://' \ - -e 's/^ goto yynewerror;//' \ - -e 's|^static char yysccsid\(.*\)|/* static char yysccsid\1 */|' \ - -e 's/^\(char \*yyname\[\]\)/const \1/' \ - -e 's/^\(char \*yyrule\[\]\)/const \1/' \ - -e 's/^\( register\) \(char \*yys;\)/\1 const \2/' \ - < y.tab.c > a2p.c - -FORCE: - -# We don't want to regenerate a2p.c, but it might appear out-of-date -# after a patch is applied or a new distribution is made. -a2p.c: a2p.y - -@sh -c true - -a2p$(OBJ_EXT): a2p.c a2py.c a2p.h EXTERN.h util.h INTERN.h \ - ../handy.h ../config.h str.h hash.h - $(CCCMD) a2p.c - -clean: - rm -f a2p$(EXE_EXT) psed *$(OBJ_EXT) $(plexe) $(plc) - -distclean: veryclean - -realclean: clean - -rmdir .depending - rm -f core $(plextract) all - rm -f $(FIRSTMAKEFILE) $(FIRSTMAKEFILE).old makefile.old - -veryclean: realclean - rm -f *~ *.orig - -# The following lint has practically everything turned on. Unfortunately, -# you have to wade through a lot of mumbo jumbo that can't be suppressed. -# If the source file has a /*NOSTRICT*/ somewhere, ignore the lint message -# for that spot. - -lint: - lint $(lintflags) $(defs) $(c) > a2p.fuzz - -depend: ../makedepend - sh ../makedepend MAKE=$(MAKE) ../cflags - -clist: - echo $(c) | tr ' ' $(TRNL) >.clist - -hlist: - echo $(h) | tr ' ' $(TRNL) >.hlist - -$(plextract): - $(RUN) $(PERL) -I../lib $@.PL - -find2perl: find2perl.PL ../config.sh - -s2p: s2p.PL ../config.sh - -# AUTOMATICALLY GENERATED MAKE DEPENDENCIES--PUT NOTHING BELOW THIS LINE -$(obj): - @ echo "You haven't done a "'"make depend" yet!'; exit 1 -makedepend: depend -!NO!SUBS! -$eunicefix Makefile -rm -f $firstmakefile diff --git a/x2p/a2p.c b/x2p/a2p.c deleted file mode 100644 index 8d6e9cde57..0000000000 --- a/x2p/a2p.c +++ /dev/null @@ -1,2941 +0,0 @@ -#ifndef lint -static const char yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93"; -#endif -#define YYBYACC 1 -#define YYMAJOR 1 -#define YYMINOR 9 -#define yyclearin (yychar=(-1)) -#define yyerrok (yyerrflag=0) -#define YYRECOVERING (yyerrflag!=0) -extern int yyparse(void); -#define YYPREFIX "yy" -#line 2 "a2p.y" -/* $RCSfile: a2p.y,v $$Revision: 4.1 $$Date: 92/08/07 18:29:12 $ - * - * Copyright (C) 1991, 1992, 1993, 1994, 1996, 1997, 1999, 2000, - * by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - * - * $Log: a2p.y,v $ - */ - -#include "INTERN.h" -#include "a2p.h" - -int root; -int begins = Nullop; -int ends = Nullop; - -#line 32 "y.tab.c" -#define BEGIN 257 -#define END 258 -#define REGEX 259 -#define SEMINEW 260 -#define NEWLINE 261 -#define COMMENT 262 -#define FUN1 263 -#define FUNN 264 -#define GRGR 265 -#define PRINT 266 -#define PRINTF 267 -#define SPRINTF_OLD 268 -#define SPRINTF_NEW 269 -#define SPLIT 270 -#define IF 271 -#define ELSE 272 -#define WHILE 273 -#define FOR 274 -#define IN 275 -#define EXIT 276 -#define NEXT 277 -#define BREAK 278 -#define CONTINUE 279 -#define RET 280 -#define GETLINE 281 -#define DO 282 -#define SUB 283 -#define GSUB 284 -#define MATCH 285 -#define FUNCTION 286 -#define USERFUN 287 -#define DELETE 288 -#define ASGNOP 289 -#define OROR 290 -#define ANDAND 291 -#define NUMBER 292 -#define VAR 293 -#define SUBSTR 294 -#define INDEX 295 -#define MATCHOP 296 -#define RELOP 297 -#define OR 298 -#define STRING 299 -#define UMINUS 300 -#define NOT 301 -#define INCR 302 -#define DECR 303 -#define FIELD 304 -#define VFIELD 305 -#define SVFIELD 306 -#define YYERRCODE 256 -short yylhs[] = { -1, - 0, 3, 6, 6, 2, 2, 7, 7, 7, 7, - 7, 7, 9, 8, 8, 11, 11, 11, 11, 11, - 15, 15, 15, 15, 14, 14, 14, 14, 13, 13, - 13, 13, 12, 12, 12, 12, 18, 18, 16, 16, - 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, - 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, - 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, - 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, - 16, 16, 16, 16, 17, 17, 17, 17, 17, 10, - 10, 10, 19, 19, 19, 1, 1, 20, 20, 20, - 20, 4, 4, 21, 21, 22, 22, 22, 22, 5, - 5, 23, 23, 23, 23, 26, 26, 24, 24, 24, - 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, - 27, 27, 27, 25, 25, 25, 25, 25, 25, 25, - 25, -}; -short yylen[] = { 2, - 2, 6, 5, 2, 3, 0, 1, 5, 10, 4, - 1, 1, 1, 1, 3, 1, 1, 1, 1, 5, - 3, 4, 4, 2, 3, 3, 3, 3, 3, 3, - 1, 3, 1, 2, 5, 3, 1, 1, 1, 1, - 1, 3, 3, 3, 3, 3, 3, 3, 2, 2, - 2, 2, 2, 2, 3, 1, 2, 3, 4, 3, - 4, 1, 3, 4, 4, 4, 4, 2, 8, 6, - 8, 8, 6, 6, 6, 6, 6, 6, 6, 6, - 8, 8, 8, 8, 1, 4, 1, 1, 2, 1, - 1, 0, 4, 4, 3, 2, 0, 1, 1, 1, - 1, 2, 0, 1, 1, 2, 2, 2, 2, 2, - 0, 3, 2, 2, 1, 1, 0, 1, 4, 2, - 4, 2, 1, 1, 1, 2, 1, 1, 2, 5, - 1, 1, 1, 6, 9, 6, 7, 10, 9, 6, - 5, -}; -short yydefred[] = { 97, - 0, 0, 99, 100, 101, 98, 0, 96, 0, 0, - 31, 0, 0, 38, 0, 0, 0, 0, 0, 0, - 0, 0, 40, 0, 0, 0, 41, 0, 0, 0, - 0, 0, 87, 0, 88, 103, 0, 11, 0, 97, - 0, 0, 0, 17, 18, 19, 0, 0, 0, 103, - 103, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 24, - 51, 52, 0, 0, 0, 0, 0, 0, 4, 0, - 103, 0, 103, 103, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 49, 50, 0, 68, 0, 0, 0, 0, 63, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 104, 105, 0, 102, 55, - 32, 28, 21, 0, 0, 0, 0, 0, 0, 30, - 0, 0, 0, 0, 48, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 103, 103, 0, 0, - 64, 65, 67, 0, 0, 0, 0, 0, 0, 0, - 0, 13, 66, 86, 0, 0, 103, 0, 0, 0, - 0, 0, 0, 124, 123, 127, 0, 103, 0, 103, - 10, 103, 0, 110, 0, 115, 0, 0, 0, 22, - 0, 61, 95, 0, 0, 97, 3, 0, 0, 0, - 0, 0, 0, 0, 103, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 103, - 103, 103, 103, 103, 8, 0, 0, 0, 0, 0, - 73, 0, 78, 0, 77, 0, 80, 0, 79, 0, - 75, 76, 0, 70, 0, 74, 132, 131, 133, 0, - 0, 0, 0, 0, 116, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 103, 0, 0, 0, 103, 103, 103, 0, 0, 0, - 103, 72, 71, 82, 81, 84, 83, 0, 69, 0, - 0, 0, 0, 0, 0, 130, 0, 0, 0, 136, - 140, 0, 0, 0, 9, 103, 103, 0, 137, 0, - 0, 103, 135, 139, 0, 138, -}; -short yydgoto[] = { 1, - 2, 7, 38, 74, 128, 39, 40, 41, 171, 104, - 75, 193, 44, 45, 46, 47, 48, 49, 106, 8, - 129, 234, 194, 195, 196, 266, 260, -}; -short yysindex[] = { 0, - 0, -52, 0, 0, 0, 0, 6281, 0, -83, -65, - 0, 27, 28, 0, 43, 46, 29, 48, 50, 51, - -218, 64, 0, -14, 65, 66, 0, 8153, 8153, 6722, - -176, -176, 0, 8153, 0, 0, 6722, 0, -165, 0, - -38, -13, 6376, 0, 0, 0, -32, -232, 8198, 0, - 0, 7770, 8198, 8198, 8153, 8153, 47, 7835, 7883, 8153, - 69, 8198, 8198, 8153, 8153, 6722, -57, -267, -57, 0, - 0, 0, -2, -210, -41, 79, 80, 85, 0, -52, - 0, 8153, 0, 0, 6722, 8153, 7931, 8153, 8153, 8153, - -32, -166, 8153, 8153, 8153, 8153, 8153, 8153, -150, 6722, - 0, 0, 6770, 0, 3731, 88, -210, -210, 0, 1055, - 93, 94, 6815, 184, 8153, 92, 6892, 96, 6939, 7003, - 8198, 97, 44, 7048, 7094, 0, 0, 5585, 0, 0, - 0, 0, 0, -210, 7172, 2108, 2108, -60, 7216, 0, - 184, 184, 184, 184, 0, 45, 45, -57, -57, -57, - -57, -176, -60, 6770, 6332, 32, 0, 0, 5632, 5700, - 0, 0, 0, -148, 184, 8153, 8153, 8153, 8153, 8001, - 102, 0, 0, 0, 8153, 8153, 0, 8198, 8198, 107, - 121, 127, 8153, 0, 0, 0, 8153, 0, -130, 0, - 0, 0, 8045, 0, -43, 0, 5899, 8153, -119, 0, - 8153, 0, 0, 1434, 1434, 0, 0, 37, 5431, 6447, - 6491, 6548, 134, 7281, 0, 6611, 7327, -210, -45, -45, - 6722, 6722, 2656, 8045, 8045, 4777, 90, -210, -210, 0, - 0, 0, 0, 0, 0, 8045, 8045, 8045, 8045, -52, - 0, 8105, 0, 8153, 0, 8153, 0, 8153, 0, 8153, - 0, 0, -96, 0, 8153, 0, 0, 0, 0, 8153, - 8153, -39, -37, 7371, 0, 124, -89, 8198, 5967, -210, - -210, -210, -210, -210, 144, 7449, 7493, 7560, 7604, 7648, - 0, 7726, 8045, 8045, 0, 0, 0, 6659, 146, 95, - 0, 0, 0, 0, 0, 0, 0, -210, 0, 4777, - 4777, 4777, 2656, -51, 6722, 0, -210, 6014, -85, 0, - 0, 151, 2656, -35, 0, 0, 0, 152, 0, 4777, - 4777, 0, 0, 0, 4777, 0, -}; -short yyrindex[] = { 0, - 0, 2742, 0, 0, 0, 0, 194, 0, 0, 0, - 0, 56, 0, 0, 111, 0, 3174, 0, 0, 0, - 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 2475, 0, - 2531, 2375, 4311, 0, 0, 0, 2057, 1630, 3897, 0, - 0, 0, 154, 154, 0, 0, 382, 0, 0, 0, - 0, 154, 105, 0, 0, 0, 818, 872, 1143, 0, - 0, 0, 437, 6065, 0, -54, -49, -44, 0, 2798, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 2324, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 4263, 492, 6065, 6065, 0, 0, - 0, 0, 0, 3222, 0, 0, 0, 0, 0, 0, - 154, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 6065, 0, 0, 0, 2425, 0, 0, - 3462, 3507, 3552, 3621, 0, 1956, 2007, 1197, 1251, 1522, - 1576, 3119, 1901, 0, -23, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 3830, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 504, 504, 0, - 0, 0, 13, 0, 0, 0, 103, 0, 0, 0, - 0, 0, 123, 0, 0, 0, 0, 0, 763, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 4830, 173, 242, - 0, 0, 140, 297, 350, 0, 0, 6065, 4878, 0, - 0, 0, 0, 0, 0, 3945, 4017, 4106, 4208, 2848, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 141, 0, 0, 0, 105, 0, 4952, - 5145, 5219, 5266, 5318, 0, 0, 0, 0, 0, 0, - 0, 0, 398, 484, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 6065, 0, 0, - 0, 0, 161, 0, 0, 0, 5534, 0, 6180, 0, - 0, 0, 161, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, -}; -short yygindex[] = { 0, - -17, 0, 0, 4597, -87, 0, 0, 0, 0, 12, - 23, 4555, -12, -8, -3, 8435, 4752, 0, -70, 0, - 0, 0, -124, -191, 0, -264, -7, -}; -#define YYTABLESIZE 8719 -short yytable[] = { 130, - 85, 285, 82, 286, 97, 319, 6, 313, 17, 95, - 93, 82, 94, 18, 96, 233, 258, 16, 19, 159, - 160, 82, 80, 82, 76, 82, 281, 82, 77, 42, - 85, 265, 156, 78, 101, 102, 98, 85, 312, 50, - 85, 85, 85, 85, 85, 85, 197, 85, 318, 82, - 126, 127, 70, 125, 99, 62, 100, 51, 85, 85, - 85, 98, 85, 85, 111, 112, 52, 53, 61, 101, - 102, 125, 203, 122, 123, 158, 63, 241, 259, 99, - 242, 97, 54, 156, 81, 55, 95, 58, 56, 59, - 60, 96, 62, 85, 85, 79, 62, 62, 62, 62, - 62, 267, 62, 62, 64, 65, 115, 138, 121, 99, - 37, 265, 85, 62, 62, 62, 24, 62, 62, 131, - 132, 265, 153, 85, 85, 133, 145, 33, 34, 35, - 152, 158, 172, 162, 163, 166, 174, 173, 98, 168, - 269, 76, 215, 128, 208, 77, 221, 37, 62, 62, - 78, 37, 37, 37, 37, 37, 99, 37, 199, 200, - 222, 128, 227, 118, 126, 127, 223, 62, 37, 37, - 37, 84, 37, 37, 251, 309, 310, 311, 62, 62, - 268, 118, 288, 289, 292, 305, 316, 306, 240, 219, - 220, 317, 322, 1, 92, 323, 324, 92, 117, 118, - 326, 117, 0, 37, 37, 0, 0, 3, 4, 5, - 308, 0, 261, 120, 0, 0, 230, 231, 232, 257, - 0, 0, 37, 66, 0, 0, 28, 0, 29, 83, - 84, 120, 0, 37, 37, 17, 17, 0, 83, 84, - 18, 18, 92, 262, 263, 19, 19, 0, 83, 84, - 83, 84, 83, 84, 83, 84, 0, 85, 85, 85, - 85, 85, 85, 85, 85, 85, 16, 16, 85, 85, - 85, 0, 125, 125, 125, 85, 83, 84, 0, 290, - 0, 85, 122, 85, 85, 85, 85, 85, 0, 85, - 85, 85, 85, 85, 85, 85, 85, 85, 0, 85, - 122, 85, 85, 85, 85, 85, 85, 0, 0, 0, - 304, 0, 62, 62, 62, 62, 62, 62, 62, 62, - 62, 24, 0, 62, 62, 62, 0, 314, 0, 0, - 62, 0, 33, 34, 35, 0, 62, 126, 62, 62, - 62, 62, 62, 0, 62, 62, 62, 62, 62, 62, - 62, 62, 62, 0, 62, 126, 62, 62, 62, 62, - 62, 62, 128, 128, 128, 0, 0, 37, 37, 37, - 37, 37, 37, 37, 37, 37, 0, 0, 37, 37, - 37, 57, 118, 118, 118, 37, 0, 0, 0, 0, - 129, 37, 0, 37, 37, 37, 37, 37, 0, 37, - 37, 37, 37, 37, 37, 37, 37, 37, 129, 37, - 0, 37, 37, 37, 37, 37, 37, 0, 57, 0, - 0, 57, 57, 57, 57, 57, 57, 0, 57, 0, - 0, 0, 120, 120, 120, 0, 89, 0, 119, 57, - 57, 0, 0, 57, 57, 0, 12, 13, 0, 0, - 0, 14, 15, 16, 0, 0, 119, 0, 0, 0, - 0, 0, 0, 0, 17, 0, 18, 19, 20, 0, - 22, 0, 0, 89, 57, 57, 89, 89, 89, 89, - 89, 89, 27, 89, 0, 31, 32, 33, 34, 35, - 0, 91, 0, 57, 89, 89, 89, 0, 89, 89, - 0, 122, 122, 122, 57, 57, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 121, 0, 0, 0, 91, 89, - 89, 91, 91, 91, 91, 0, 91, 0, 91, 0, - 0, 0, 121, 0, 92, 0, 0, 0, 0, 91, - 91, 91, 0, 91, 91, 0, 126, 126, 126, 89, - 89, 0, 92, 0, 0, 92, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 91, 91, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 91, 0, 0, 0, 0, 0, 129, - 129, 129, 0, 0, 91, 91, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 92, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 57, 57, - 57, 57, 57, 57, 57, 57, 57, 0, 0, 57, - 57, 57, 0, 0, 0, 0, 57, 119, 119, 119, - 0, 0, 57, 0, 57, 57, 57, 57, 57, 0, - 57, 57, 57, 57, 57, 57, 57, 57, 57, 0, - 57, 0, 57, 57, 57, 57, 57, 57, 0, 0, - 0, 0, 0, 89, 89, 89, 89, 89, 89, 89, - 89, 89, 0, 0, 89, 89, 89, 0, 0, 0, - 0, 89, 0, 0, 0, 0, 0, 89, 0, 89, - 89, 89, 89, 89, 0, 89, 89, 89, 89, 89, - 89, 89, 89, 89, 0, 89, 0, 89, 89, 89, - 89, 89, 89, 121, 121, 121, 0, 0, 91, 91, - 91, 91, 91, 91, 91, 91, 91, 0, 0, 91, - 91, 91, 23, 92, 92, 92, 91, 0, 92, 0, - 0, 0, 91, 0, 91, 91, 91, 91, 91, 0, - 91, 91, 91, 91, 91, 91, 91, 91, 91, 0, - 91, 0, 91, 91, 91, 91, 91, 91, 0, 23, - 0, 0, 23, 23, 23, 23, 23, 23, 0, 23, - 0, 0, 0, 0, 0, 0, 0, 54, 0, 0, - 23, 23, 23, 0, 23, 23, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 54, 23, 23, 54, 54, 54, - 54, 54, 54, 0, 54, 0, 0, 0, 0, 0, - 0, 39, 0, 0, 23, 54, 54, 54, 0, 54, - 54, 0, 0, 0, 0, 23, 23, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 39, 0, - 54, 39, 39, 39, 39, 39, 39, 0, 39, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 39, - 39, 39, 0, 39, 39, 0, 0, 0, 0, 0, - 54, 54, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 39, 39, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 39, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 39, 39, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 23, - 23, 23, 23, 23, 23, 23, 23, 23, 0, 0, - 23, 23, 23, 0, 0, 0, 0, 23, 0, 0, - 0, 0, 0, 23, 0, 23, 23, 23, 23, 23, - 0, 23, 23, 0, 23, 23, 23, 23, 23, 23, - 0, 23, 0, 23, 23, 23, 23, 23, 23, 0, - 0, 0, 0, 0, 54, 54, 54, 54, 54, 54, - 54, 54, 54, 0, 0, 54, 54, 54, 0, 0, - 0, 0, 54, 0, 66, 161, 0, 28, 54, 29, - 54, 54, 54, 54, 54, 0, 54, 54, 54, 54, - 54, 54, 54, 54, 54, 0, 54, 86, 54, 54, - 54, 54, 54, 54, 0, 0, 0, 0, 39, 39, - 39, 39, 39, 39, 39, 39, 39, 0, 0, 39, - 39, 39, 53, 0, 0, 0, 39, 0, 0, 0, - 0, 0, 39, 0, 39, 39, 39, 39, 39, 0, - 39, 39, 39, 39, 39, 39, 39, 39, 39, 0, - 39, 0, 39, 0, 0, 39, 39, 39, 0, 53, - 0, 0, 53, 53, 53, 53, 53, 53, 0, 53, - 0, 0, 0, 0, 0, 0, 44, 0, 0, 0, - 53, 53, 53, 0, 53, 53, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 44, 0, 53, 44, 44, 44, 44, - 44, 44, 0, 44, 0, 0, 0, 0, 0, 0, - 45, 0, 0, 0, 44, 44, 44, 0, 44, 44, - 0, 0, 0, 0, 0, 53, 53, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 45, 0, 44, - 45, 45, 45, 45, 45, 45, 0, 45, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 45, 45, - 45, 0, 45, 45, 0, 0, 0, 12, 13, 44, - 44, 0, 14, 15, 16, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 17, 0, 18, 19, 20, - 0, 22, 0, 45, 0, 0, 23, 24, 25, 26, - 0, 0, 0, 27, 0, 0, 31, 32, 33, 34, - 35, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 45, 45, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 53, - 53, 53, 53, 53, 53, 53, 53, 53, 0, 0, - 53, 53, 53, 0, 0, 0, 0, 53, 0, 0, - 0, 0, 0, 53, 0, 53, 53, 53, 53, 53, - 0, 53, 53, 53, 53, 53, 53, 53, 53, 53, - 0, 53, 0, 53, 53, 53, 53, 53, 53, 0, - 0, 0, 0, 44, 44, 44, 44, 44, 44, 44, - 44, 44, 0, 0, 44, 44, 44, 0, 0, 0, - 0, 44, 0, 66, 0, 0, 28, 44, 29, 44, - 44, 44, 44, 44, 0, 44, 44, 44, 44, 44, - 44, 44, 44, 44, 0, 44, 0, 44, 44, 44, - 44, 44, 44, 0, 0, 0, 0, 45, 45, 45, - 45, 45, 45, 45, 45, 45, 0, 0, 45, 45, - 45, 46, 0, 0, 0, 45, 0, 0, 0, 0, - 0, 45, 0, 45, 45, 45, 45, 45, 0, 45, - 45, 45, 45, 45, 45, 45, 45, 45, 0, 45, - 0, 45, 45, 45, 45, 45, 45, 0, 46, 0, - 0, 46, 46, 46, 46, 46, 46, 0, 46, 0, - 0, 0, 0, 0, 0, 47, 0, 0, 0, 46, - 46, 46, 0, 46, 46, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 47, 0, 46, 47, 47, 47, 47, 47, - 47, 0, 47, 0, 0, 0, 0, 0, 0, 39, - 0, 0, 0, 47, 47, 47, 0, 47, 47, 0, - 0, 0, 0, 0, 46, 46, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 39, 0, 47, 39, - 39, 39, 39, 39, 39, 0, 39, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 39, 39, 39, - 0, 39, 39, 0, 126, 127, 12, 13, 47, 47, - 0, 14, 15, 16, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 17, 0, 18, 19, 20, 0, - 22, 0, 39, 39, 0, 23, 24, 25, 26, 0, - 0, 0, 27, 0, 0, 31, 32, 33, 34, 35, - 0, 39, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 39, 39, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 46, 46, - 46, 46, 46, 46, 46, 46, 46, 0, 0, 46, - 46, 46, 0, 0, 0, 0, 46, 0, 0, 0, - 0, 0, 46, 0, 46, 46, 46, 46, 46, 0, - 46, 46, 46, 46, 46, 46, 46, 46, 46, 0, - 46, 0, 46, 46, 46, 46, 46, 46, 0, 0, - 0, 0, 47, 47, 47, 47, 47, 47, 47, 47, - 47, 0, 0, 47, 47, 47, 0, 0, 0, 0, - 47, 0, 0, 0, 0, 0, 47, 0, 47, 47, - 47, 47, 47, 0, 47, 47, 47, 47, 47, 47, - 47, 47, 47, 0, 47, 0, 47, 47, 47, 47, - 47, 47, 0, 0, 0, 0, 39, 39, 39, 39, - 39, 39, 39, 39, 39, 0, 0, 39, 39, 39, - 36, 0, 0, 0, 39, 0, 0, 0, 0, 0, - 39, 0, 39, 39, 39, 39, 39, 0, 0, 39, - 39, 39, 39, 39, 39, 39, 39, 0, 39, 0, - 39, 0, 0, 39, 39, 39, 0, 36, 0, 0, - 36, 36, 36, 36, 36, 36, 0, 36, 0, 0, - 0, 0, 0, 0, 0, 42, 0, 0, 36, 36, - 36, 0, 36, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 36, 36, 42, 42, 0, 42, 42, - 42, 0, 0, 0, 0, 0, 43, 0, 0, 0, - 0, 0, 36, 42, 42, 42, 0, 42, 42, 0, - 0, 0, 0, 36, 36, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 43, 43, 42, 43, - 43, 43, 0, 0, 0, 0, 33, 0, 0, 0, - 0, 0, 0, 0, 43, 43, 43, 0, 43, 43, - 0, 0, 0, 0, 0, 0, 0, 0, 42, 42, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 33, 33, 0, 43, - 33, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 33, 33, 33, 0, 33, 33, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 43, - 43, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 37, 0, 33, - 28, 0, 29, 0, 0, 0, 0, 36, 36, 36, - 36, 36, 36, 36, 36, 36, 0, 0, 36, 36, - 36, 0, 0, 0, 0, 36, 0, 0, 0, 33, - 33, 36, 0, 36, 36, 36, 36, 36, 0, 36, - 0, 0, 36, 36, 36, 36, 36, 36, 0, 36, - 0, 36, 36, 36, 36, 36, 36, 0, 0, 0, - 0, 0, 42, 42, 42, 42, 42, 42, 42, 42, - 42, 0, 0, 42, 42, 42, 0, 0, 0, 0, - 42, 0, 0, 0, 0, 0, 42, 0, 42, 42, - 42, 42, 42, 0, 42, 42, 42, 42, 42, 42, - 42, 42, 42, 0, 42, 0, 42, 42, 42, 42, - 42, 42, 0, 43, 43, 43, 43, 43, 43, 43, - 43, 43, 0, 0, 43, 43, 43, 0, 0, 0, - 0, 43, 0, 0, 0, 0, 0, 43, 0, 43, - 43, 43, 43, 43, 0, 43, 43, 43, 43, 43, - 43, 43, 43, 43, 0, 43, 0, 43, 43, 43, - 43, 43, 43, 33, 33, 33, 33, 33, 33, 33, - 33, 33, 0, 34, 33, 33, 33, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 33, 0, 33, - 33, 33, 33, 33, 0, 33, 33, 33, 33, 33, - 33, 33, 33, 33, 0, 33, 0, 33, 33, 33, - 33, 33, 33, 34, 34, 0, 11, 34, 126, 127, - 12, 13, 0, 0, 14, 14, 15, 16, 0, 0, - 0, 34, 34, 34, 0, 34, 34, 0, 17, 0, - 18, 19, 20, 0, 22, 0, 0, 0, 0, 23, - 24, 25, 26, 0, 0, 0, 27, 0, 30, 31, - 32, 33, 34, 35, 14, 0, 34, 14, 0, 14, - 0, 0, 0, 0, 15, 0, 0, 0, 0, 0, - 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 34, 34, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 15, 0, 0, 15, 0, 15, - 0, 0, 0, 0, 12, 0, 0, 0, 0, 0, - 0, 0, 0, 15, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 14, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 12, 0, 0, 12, 0, 12, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 7, 0, 0, 12, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 15, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 7, 0, 0, 7, 0, 7, 0, 0, 0, 0, - 34, 34, 34, 34, 34, 34, 34, 34, 34, 7, - 0, 34, 34, 34, 0, 0, 0, 12, 0, 0, - 0, 0, 0, 0, 34, 0, 34, 34, 34, 34, - 34, 0, 34, 34, 34, 34, 34, 34, 34, 34, - 34, 0, 34, 0, 34, 34, 34, 34, 34, 34, - 0, 14, 14, 14, 14, 14, 14, 14, 14, 0, - 0, 0, 14, 14, 14, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 14, 0, 14, 14, 14, - 14, 14, 0, 0, 0, 0, 14, 14, 14, 14, - 0, 0, 0, 14, 0, 14, 14, 14, 14, 14, - 14, 15, 15, 15, 15, 15, 15, 15, 15, 0, - 0, 0, 15, 15, 15, 66, 0, 0, 28, 0, - 29, 0, 0, 0, 0, 15, 0, 15, 15, 15, - 15, 15, 0, 0, 0, 0, 15, 15, 15, 15, - 0, 0, 0, 15, 0, 15, 15, 15, 15, 15, - 15, 12, 12, 12, 12, 0, 12, 12, 12, 0, - 0, 6, 12, 12, 12, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 12, 0, 12, 12, 12, - 12, 12, 0, 0, 0, 0, 12, 12, 12, 12, - 0, 0, 0, 12, 0, 12, 12, 12, 12, 12, - 12, 6, 0, 0, 6, 0, 6, 7, 7, 7, - 7, 7, 7, 7, 7, 0, 0, 5, 7, 7, - 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 7, 0, 7, 7, 7, 7, 7, 0, 0, - 0, 0, 7, 7, 7, 7, 0, 0, 0, 7, - 0, 7, 7, 7, 7, 7, 7, 5, 0, 0, - 5, 0, 5, 0, 0, 0, 0, 2, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 6, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, - 2, 0, 2, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 12, 13, - 5, 178, 179, 14, 15, 16, 0, 0, 0, 0, - 0, 183, 184, 185, 186, 187, 17, 0, 18, 19, - 20, 0, 22, 189, 0, 0, 0, 23, 24, 25, - 26, 0, 0, 0, 27, 0, 0, 31, 32, 33, - 34, 35, 0, 0, 0, 0, 0, 0, 0, 0, - 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 6, 6, - 6, 0, 0, 0, 6, 6, 0, 0, 0, 6, - 6, 6, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 6, 0, 6, 6, 6, 6, 6, 0, - 0, 0, 0, 6, 6, 6, 6, 0, 0, 0, - 6, 0, 6, 6, 6, 6, 6, 6, 0, 0, - 0, 0, 0, 0, 5, 5, 5, 0, 0, 0, - 5, 5, 0, 0, 0, 5, 5, 5, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, - 5, 5, 5, 5, 5, 0, 0, 0, 0, 5, - 5, 5, 5, 0, 0, 0, 5, 0, 5, 5, - 5, 5, 5, 5, 2, 2, 2, 0, 0, 0, - 2, 2, 0, 0, 0, 2, 2, 2, 60, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, - 2, 2, 2, 2, 2, 0, 0, 0, 0, 2, - 2, 2, 2, 0, 0, 0, 2, 0, 2, 2, - 2, 2, 2, 2, 0, 60, 0, 0, 60, 60, - 60, 60, 60, 60, 0, 60, 0, 0, 0, 0, - 0, 0, 0, 56, 0, 0, 60, 60, 60, 0, - 60, 60, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 56, 60, 60, 56, 56, 56, 56, 56, 56, 0, - 56, 58, 0, 0, 0, 0, 0, 0, 0, 0, - 60, 56, 56, 0, 0, 56, 56, 0, 0, 0, - 0, 60, 60, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 58, 0, - 0, 0, 58, 58, 0, 58, 56, 56, 58, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 58, - 58, 58, 0, 58, 58, 56, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 56, 56, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 58, 58, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 58, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 58, 58, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 60, 60, 60, 60, 60, - 60, 60, 60, 60, 0, 0, 60, 60, 60, 0, - 0, 0, 0, 60, 0, 0, 0, 0, 0, 60, - 0, 60, 60, 60, 60, 60, 0, 60, 60, 60, - 60, 0, 60, 60, 60, 60, 0, 60, 0, 60, - 60, 60, 0, 0, 0, 0, 0, 0, 0, 0, - 56, 56, 56, 56, 56, 56, 56, 56, 56, 0, - 0, 56, 56, 56, 0, 0, 0, 0, 56, 0, - 0, 0, 0, 0, 56, 0, 56, 56, 56, 56, - 56, 29, 56, 56, 56, 56, 0, 56, 56, 56, - 56, 0, 56, 0, 56, 56, 56, 0, 58, 58, - 58, 58, 58, 58, 0, 0, 58, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 58, 0, 29, 0, - 0, 0, 29, 29, 0, 29, 25, 58, 29, 0, - 58, 58, 58, 58, 58, 58, 58, 58, 58, 29, - 29, 29, 58, 29, 29, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 25, 0, 0, 0, 25, 25, 0, - 25, 27, 0, 25, 29, 29, 0, 0, 0, 0, - 0, 0, 0, 0, 25, 25, 25, 0, 25, 25, - 0, 0, 0, 29, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 29, 29, 0, 0, 27, 0, - 0, 0, 27, 27, 0, 27, 0, 0, 27, 25, - 25, 0, 0, 0, 0, 0, 0, 0, 0, 27, - 27, 27, 0, 27, 27, 0, 0, 0, 25, 0, - 26, 0, 0, 0, 0, 0, 0, 0, 0, 25, - 25, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 27, 27, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 26, 0, 0, - 0, 26, 26, 27, 26, 0, 0, 26, 0, 0, - 0, 0, 0, 0, 27, 27, 0, 0, 26, 26, - 26, 0, 26, 26, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 26, 26, 0, 0, 0, 29, 29, - 29, 29, 29, 29, 0, 0, 29, 0, 0, 0, - 0, 0, 26, 0, 0, 0, 29, 0, 0, 0, - 0, 0, 0, 26, 26, 0, 0, 29, 0, 0, - 29, 29, 29, 29, 29, 29, 29, 29, 29, 0, - 0, 0, 29, 25, 25, 25, 25, 25, 25, 0, - 66, 25, 0, 28, 157, 29, 0, 0, 0, 0, - 0, 25, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 25, 86, 0, 25, 25, 25, 25, 25, - 25, 25, 25, 25, 0, 0, 0, 25, 27, 27, - 27, 27, 27, 27, 0, 0, 27, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 27, 0, 0, 59, - 0, 0, 0, 0, 0, 0, 0, 27, 0, 0, - 27, 27, 27, 27, 27, 27, 27, 27, 27, 0, - 0, 0, 27, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 59, 0, 0, 0, - 59, 59, 0, 59, 0, 0, 59, 26, 26, 26, - 26, 26, 26, 0, 0, 26, 0, 59, 59, 59, - 0, 59, 59, 0, 0, 26, 92, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 26, 0, 0, 26, - 26, 26, 26, 26, 26, 26, 26, 26, 0, 0, - 0, 26, 59, 59, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 92, 0, 0, 0, 92, 92, 0, - 92, 59, 0, 92, 20, 0, 0, 0, 0, 0, - 0, 0, 59, 59, 92, 92, 92, 0, 92, 92, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 20, 0, 0, 0, 20, 20, 0, 20, 92, - 92, 20, 0, 12, 13, 0, 0, 0, 14, 15, - 16, 0, 20, 20, 20, 0, 20, 0, 92, 0, - 0, 17, 0, 18, 19, 20, 35, 22, 0, 92, - 92, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 20, 20, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 35, 0, 0, 20, 35, 35, 0, - 35, 0, 0, 35, 0, 0, 0, 20, 20, 0, - 0, 0, 0, 0, 35, 35, 35, 0, 35, 0, - 0, 0, 0, 0, 0, 0, 59, 59, 59, 59, - 59, 59, 0, 0, 59, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 59, 93, 0, 0, 0, 35, - 35, 0, 0, 0, 0, 59, 0, 0, 59, 59, - 59, 59, 59, 59, 59, 59, 59, 0, 35, 0, - 59, 0, 0, 0, 0, 0, 0, 0, 0, 35, - 35, 0, 93, 0, 0, 0, 93, 93, 0, 93, - 0, 0, 93, 92, 92, 92, 92, 92, 92, 0, - 0, 92, 0, 93, 93, 93, 0, 93, 0, 0, - 0, 92, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 92, 0, 0, 92, 92, 92, 0, 0, - 0, 0, 92, 92, 0, 0, 0, 92, 93, 93, - 0, 20, 20, 20, 20, 20, 20, 94, 0, 20, - 0, 0, 0, 0, 0, 0, 0, 93, 0, 20, - 0, 0, 0, 0, 0, 0, 0, 0, 93, 93, - 20, 0, 0, 20, 20, 20, 0, 0, 0, 0, - 20, 20, 0, 0, 94, 20, 0, 0, 94, 94, - 0, 94, 0, 0, 94, 0, 0, 0, 0, 0, - 0, 0, 90, 0, 0, 94, 94, 94, 0, 94, - 0, 0, 0, 35, 35, 35, 35, 35, 35, 0, - 0, 35, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 35, 0, 0, 0, 0, 0, 0, 0, 90, - 94, 94, 35, 90, 90, 35, 35, 35, 0, 90, - 16, 0, 35, 35, 0, 0, 0, 35, 0, 94, - 90, 90, 90, 0, 90, 0, 0, 0, 0, 0, - 94, 94, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 16, 0, 0, - 0, 16, 16, 0, 16, 90, 90, 16, 0, 0, - 0, 0, 93, 93, 93, 93, 93, 93, 16, 16, - 93, 0, 0, 0, 90, 0, 0, 0, 0, 0, - 93, 0, 0, 0, 0, 90, 90, 0, 0, 0, - 0, 93, 0, 0, 93, 93, 93, 0, 0, 0, - 0, 93, 93, 16, 16, 0, 93, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 16, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 16, 16, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 94, 94, 94, 94, 94, 94, - 0, 0, 94, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 94, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 94, 0, 0, 94, 94, 94, 0, - 0, 0, 0, 94, 94, 0, 0, 0, 94, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 90, - 90, 90, 90, 90, 90, 0, 0, 90, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 90, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 90, 0, - 0, 90, 90, 90, 0, 0, 0, 0, 90, 90, - 0, 43, 0, 90, 0, 0, 0, 16, 16, 16, - 16, 16, 16, 0, 0, 16, 0, 0, 0, 0, - 0, 0, 0, 0, 43, 16, 0, 0, 0, 0, - 0, 43, 0, 0, 0, 0, 16, 0, 0, 16, - 16, 16, 0, 105, 0, 0, 110, 105, 105, 113, - 114, 16, 117, 119, 120, 0, 105, 105, 124, 125, - 43, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 135, 0, 0, 43, - 139, 141, 142, 143, 144, 0, 107, 108, 0, 0, - 0, 0, 0, 0, 43, 0, 0, 155, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 165, - 0, 0, 0, 0, 0, 105, 0, 134, 0, 136, - 137, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 43, 43, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 155, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 209, 210, 211, 212, 214, 0, 0, 0, 0, 216, - 217, 0, 105, 105, 0, 0, 0, 224, 0, 0, - 0, 225, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 236, 204, 205, 237, 0, 0, 238, 239, - 0, 0, 0, 0, 0, 0, 0, 0, 57, 0, - 0, 0, 0, 218, 0, 43, 43, 264, 0, 68, - 68, 0, 71, 72, 226, 68, 228, 0, 229, 0, - 0, 0, 0, 0, 68, 0, 276, 0, 277, 0, - 278, 0, 279, 0, 280, 0, 0, 0, 0, 282, - 0, 253, 0, 0, 283, 284, 66, 0, 0, 28, - 0, 29, 105, 0, 0, 0, 270, 271, 272, 273, - 274, 0, 0, 0, 0, 192, 0, 0, 0, 0, - 0, 0, 43, 0, 68, 68, 68, 68, 68, 68, - 0, 0, 0, 0, 0, 0, 68, 0, 0, 43, - 0, 68, 0, 0, 68, 68, 0, 0, 68, 114, - 68, 68, 114, 0, 114, 68, 68, 298, 0, 0, - 0, 300, 301, 302, 0, 0, 68, 307, 114, 0, - 68, 0, 68, 68, 68, 68, 0, 0, 0, 190, - 0, 0, 0, 202, 0, 0, 68, 0, 0, 0, - 0, 0, 320, 321, 0, 0, 68, 113, 325, 0, - 113, 0, 113, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 113, 0, 0, 0, - 0, 0, 0, 0, 68, 0, 0, 0, 0, 0, - 0, 0, 114, 0, 114, 0, 0, 0, 0, 0, - 68, 68, 68, 68, 0, 68, 0, 68, 68, 0, - 0, 0, 0, 0, 0, 68, 68, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 68, 68, 68, - 68, 107, 0, 0, 107, 0, 107, 0, 0, 0, - 113, 0, 113, 0, 0, 0, 0, 0, 0, 0, - 107, 0, 0, 0, 0, 68, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 68, 68, 68, - 68, 68, 0, 68, 68, 68, 177, 126, 127, 12, - 13, 0, 178, 179, 14, 15, 16, 180, 0, 181, - 182, 0, 183, 184, 185, 186, 187, 17, 188, 18, - 19, 20, 0, 22, 189, 0, 0, 0, 23, 24, - 25, 26, 0, 0, 107, 27, 107, 0, 31, 32, - 33, 34, 35, 0, 0, 0, 0, 0, 0, 114, - 0, 0, 114, 114, 0, 114, 114, 114, 114, 114, - 114, 114, 114, 114, 0, 114, 114, 114, 114, 114, - 114, 114, 114, 114, 114, 0, 114, 114, 0, 0, - 0, 114, 114, 114, 114, 0, 0, 0, 114, 0, - 0, 114, 114, 114, 114, 114, 0, 113, 0, 0, - 113, 113, 0, 113, 113, 113, 113, 113, 113, 113, - 113, 113, 0, 113, 113, 113, 113, 113, 113, 113, - 113, 113, 113, 0, 113, 113, 0, 0, 0, 113, - 113, 113, 113, 0, 0, 0, 113, 0, 0, 113, - 113, 113, 113, 113, 108, 0, 0, 108, 0, 108, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 108, 0, 0, 0, 0, 0, 0, - 0, 107, 0, 0, 107, 107, 0, 107, 107, 107, - 107, 107, 107, 107, 107, 107, 0, 107, 107, 107, - 107, 107, 107, 107, 107, 107, 107, 0, 107, 107, - 0, 0, 0, 107, 107, 107, 107, 0, 0, 0, - 107, 0, 0, 107, 107, 107, 107, 107, 109, 0, - 0, 109, 0, 109, 0, 0, 0, 108, 0, 108, - 0, 0, 0, 0, 0, 0, 0, 109, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 106, 0, 0, 106, 0, - 106, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 106, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 109, 0, 109, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 112, 0, 0, - 112, 0, 112, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 112, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 106, 0, - 106, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 108, 0, 0, 108, 108, 0, - 108, 108, 108, 108, 108, 108, 108, 108, 108, 0, - 108, 108, 108, 108, 108, 108, 108, 108, 108, 108, - 0, 108, 108, 0, 0, 0, 108, 108, 108, 108, - 112, 0, 112, 108, 0, 0, 108, 108, 108, 108, - 108, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 66, 243, 0, 28, 244, 29, 0, 0, 109, 0, - 0, 109, 109, 0, 109, 109, 109, 109, 109, 109, - 109, 109, 109, 86, 109, 109, 109, 109, 109, 109, - 109, 109, 109, 109, 0, 109, 109, 0, 0, 0, - 109, 109, 109, 109, 0, 0, 0, 109, 0, 0, - 109, 109, 109, 109, 109, 106, 0, 0, 106, 106, - 0, 106, 106, 106, 106, 106, 106, 106, 106, 106, - 0, 106, 106, 106, 106, 106, 106, 106, 106, 106, - 106, 0, 106, 106, 0, 0, 0, 106, 106, 106, - 106, 0, 0, 0, 106, 0, 0, 106, 106, 106, - 106, 106, 0, 141, 0, 0, 141, 112, 141, 0, - 112, 112, 0, 112, 112, 112, 112, 112, 112, 112, - 112, 112, 141, 112, 112, 112, 112, 112, 112, 112, - 112, 112, 112, 0, 112, 112, 0, 0, 0, 112, - 112, 112, 112, 0, 0, 0, 112, 0, 0, 112, - 112, 112, 112, 112, 66, 0, 0, 28, 0, 29, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 192, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 141, 0, 141, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 66, 0, 0, 28, 0, 29, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 192, 0, 0, 12, 13, 0, 0, 0, 14, 15, - 16, 0, 0, 0, 0, 0, 0, 190, 0, 191, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 0, 0, 66, - 0, 0, 28, 0, 29, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 190, 0, 206, 0, 192, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 141, 0, 0, 141, 141, 0, 141, - 141, 141, 141, 141, 141, 141, 141, 141, 0, 141, - 141, 141, 141, 141, 141, 141, 141, 141, 141, 0, - 141, 141, 190, 0, 207, 141, 141, 141, 141, 0, - 0, 0, 141, 0, 0, 141, 141, 141, 141, 141, - 0, 0, 0, 0, 177, 0, 0, 12, 13, 0, - 178, 179, 14, 15, 16, 180, 0, 181, 182, 0, - 183, 184, 185, 186, 187, 17, 188, 18, 19, 20, - 0, 22, 189, 0, 0, 0, 23, 24, 25, 26, - 0, 0, 0, 27, 0, 0, 31, 32, 33, 34, - 35, 177, 0, 0, 12, 13, 0, 178, 179, 14, - 15, 16, 180, 0, 181, 182, 0, 183, 184, 185, - 186, 187, 17, 188, 18, 19, 20, 0, 22, 189, - 0, 0, 0, 23, 24, 25, 26, 0, 0, 0, - 27, 0, 0, 31, 32, 33, 34, 35, 66, 0, - 0, 28, 0, 29, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 192, 0, 177, - 0, 0, 12, 13, 0, 178, 179, 14, 15, 16, - 180, 0, 181, 182, 0, 183, 184, 185, 186, 187, - 17, 188, 18, 19, 20, 0, 22, 189, 0, 0, - 0, 23, 24, 25, 26, 0, 0, 0, 27, 0, - 0, 31, 32, 33, 34, 35, 66, 0, 0, 28, - 0, 29, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 190, 0, 235, 0, 192, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 66, 0, 0, 28, 0, 29, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 192, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 190, - 0, 291, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 111, 0, 0, 111, 0, 111, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 111, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 190, 0, 315, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 177, 0, - 0, 12, 13, 0, 178, 179, 14, 15, 16, 180, - 0, 181, 182, 0, 183, 184, 185, 186, 187, 17, - 188, 18, 19, 20, 0, 22, 189, 111, 0, 111, - 23, 24, 25, 26, 0, 0, 0, 27, 0, 0, - 31, 32, 33, 34, 35, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 134, - 0, 0, 134, 0, 134, 0, 177, 0, 0, 12, - 13, 0, 178, 179, 14, 15, 16, 180, 134, 181, - 182, 0, 183, 184, 185, 186, 187, 17, 188, 18, - 19, 20, 0, 22, 189, 0, 0, 0, 23, 24, - 25, 26, 0, 0, 0, 27, 0, 0, 31, 32, - 33, 34, 35, 177, 0, 0, 12, 13, 0, 178, - 179, 14, 15, 16, 180, 0, 181, 182, 0, 183, - 184, 185, 186, 187, 17, 188, 18, 19, 20, 0, - 22, 189, 134, 0, 134, 23, 24, 25, 26, 0, - 0, 0, 27, 0, 0, 31, 32, 33, 34, 35, - 37, 0, 0, 28, 111, 29, 0, 111, 111, 0, - 111, 111, 111, 111, 111, 111, 0, 111, 111, 0, - 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, - 0, 111, 111, 0, 0, 0, 111, 111, 111, 111, - 0, 0, 0, 111, 0, 0, 111, 111, 111, 111, - 111, 66, 0, 0, 28, 157, 29, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 89, 0, 90, 86, 0, 0, 0, 0, 0, - 0, 0, 0, 36, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 66, 0, 0, 28, 0, - 29, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 89, 0, 90, 86, 134, - 0, 0, 134, 134, 0, 134, 134, 134, 134, 134, - 134, 0, 134, 134, 0, 134, 134, 134, 134, 134, - 134, 134, 134, 134, 134, 0, 134, 134, 0, 0, - 0, 134, 134, 134, 134, 0, 0, 0, 134, 0, - 0, 134, 134, 134, 134, 134, 66, 245, 0, 28, - 246, 29, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 86, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 66, 247, 0, 28, 248, 29, 0, 9, 10, 11, - 0, 0, 0, 12, 13, 0, 0, 0, 14, 15, - 16, 0, 0, 86, 0, 0, 0, 0, 0, 0, - 0, 17, 0, 18, 19, 20, 21, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 30, 31, 32, 33, 34, 35, 66, 249, 0, - 28, 250, 29, 0, 12, 13, 0, 0, 0, 14, - 15, 16, 0, 0, 0, 0, 0, 0, 0, 0, - 86, 0, 17, 0, 18, 19, 20, 0, 22, 0, - 0, 0, 0, 23, 24, 25, 26, 87, 88, 0, - 27, 0, 0, 31, 32, 33, 34, 35, 12, 13, - 0, 0, 0, 14, 15, 16, 0, 0, 0, 0, - 66, 254, 0, 28, 255, 29, 17, 0, 18, 19, - 20, 0, 22, 0, 0, 0, 0, 23, 24, 25, - 26, 87, 88, 86, 27, 0, 0, 31, 32, 33, - 34, 35, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 37, 0, - 0, 28, 0, 29, 0, 0, 0, 0, 0, 12, - 13, 0, 0, 0, 14, 15, 16, 303, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 17, 0, 18, - 19, 20, 0, 22, 0, 0, 0, 0, 23, 24, - 25, 26, 0, 0, 0, 27, 0, 0, 31, 32, - 33, 34, 35, 12, 13, 0, 0, 0, 14, 15, - 16, 37, 0, 0, 28, 0, 29, 0, 0, 0, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 154, - 12, 13, 28, 0, 29, 14, 15, 16, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 17, 0, - 18, 19, 20, 0, 22, 0, 0, 0, 0, 23, - 24, 25, 26, 0, 0, 0, 27, 0, 0, 31, - 32, 33, 34, 35, 66, 0, 0, 28, 164, 29, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 12, 13, 0, 0, 86, 14, 15, - 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 11, 0, 0, - 0, 12, 13, 0, 0, 0, 14, 15, 16, 0, - 0, 66, 0, 0, 28, 167, 29, 0, 0, 17, - 0, 18, 19, 20, 0, 22, 0, 0, 0, 0, - 23, 24, 25, 26, 86, 0, 0, 27, 0, 30, - 31, 32, 33, 34, 35, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 66, 0, - 11, 28, 169, 29, 12, 13, 0, 0, 0, 14, - 15, 16, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 86, 17, 0, 18, 19, 20, 0, 22, 0, - 0, 0, 0, 23, 24, 25, 26, 0, 0, 0, - 27, 0, 30, 31, 32, 33, 34, 35, 11, 0, - 0, 0, 12, 13, 0, 0, 0, 14, 15, 16, - 0, 0, 66, 0, 0, 28, 170, 29, 0, 0, - 17, 0, 18, 19, 20, 0, 22, 0, 0, 0, - 0, 23, 24, 25, 26, 86, 0, 0, 27, 0, - 30, 31, 32, 33, 34, 35, 0, 12, 13, 0, - 0, 0, 14, 15, 16, 0, 0, 66, 0, 0, - 28, 175, 29, 0, 0, 17, 0, 18, 19, 20, - 0, 22, 0, 0, 0, 0, 23, 24, 25, 26, - 86, 0, 0, 27, 0, 0, 31, 32, 33, 34, - 35, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 66, 0, 0, 28, 176, 29, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 12, 13, 86, 0, 0, 14, - 15, 16, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 17, 0, 18, 19, 20, 0, 22, 0, - 0, 0, 0, 23, 24, 25, 26, 0, 0, 0, - 27, 0, 0, 31, 32, 33, 34, 35, 0, 0, - 0, 12, 13, 0, 0, 0, 14, 15, 16, 0, - 0, 66, 0, 0, 28, 0, 29, 0, 0, 17, - 0, 18, 19, 20, 0, 22, 0, 0, 0, 198, - 23, 24, 25, 26, 86, 0, 0, 27, 0, 0, - 31, 32, 33, 34, 35, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 66, 0, 0, 28, 0, - 29, 0, 0, 0, 0, 12, 13, 0, 0, 0, - 14, 15, 16, 201, 0, 0, 0, 0, 86, 0, - 0, 0, 0, 17, 0, 18, 19, 20, 0, 22, - 0, 0, 0, 0, 23, 24, 25, 26, 0, 0, - 0, 27, 0, 0, 31, 32, 33, 34, 35, 0, - 12, 13, 0, 0, 0, 14, 15, 16, 0, 0, - 66, 252, 0, 28, 0, 29, 0, 0, 17, 0, - 18, 19, 20, 0, 22, 0, 0, 0, 0, 23, - 24, 25, 26, 86, 0, 0, 27, 0, 0, 31, - 32, 33, 34, 35, 0, 0, 12, 13, 0, 0, - 0, 14, 15, 16, 0, 0, 66, 256, 0, 28, - 0, 29, 0, 0, 17, 0, 18, 19, 20, 0, - 22, 0, 0, 0, 0, 23, 24, 25, 26, 86, - 0, 0, 27, 0, 0, 31, 32, 33, 34, 35, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 66, 287, 0, 28, 0, 29, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 86, 12, 13, 0, 0, 0, 14, - 15, 16, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 17, 0, 18, 19, 20, 0, 22, 0, - 0, 0, 0, 23, 24, 25, 26, 0, 0, 0, - 27, 0, 0, 31, 32, 33, 34, 35, 12, 13, - 0, 0, 0, 14, 15, 16, 0, 0, 66, 293, - 0, 28, 0, 29, 0, 0, 17, 0, 18, 19, - 20, 0, 22, 0, 0, 0, 0, 23, 24, 25, - 26, 86, 0, 0, 27, 0, 0, 31, 32, 33, - 34, 35, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 66, 294, 0, 28, 0, 29, 0, 0, - 0, 0, 0, 12, 13, 0, 0, 0, 14, 15, - 16, 0, 0, 0, 0, 86, 0, 0, 0, 0, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 0, 0, 12, - 13, 0, 0, 0, 14, 15, 16, 0, 0, 66, - 295, 0, 28, 0, 29, 0, 0, 17, 0, 18, - 19, 20, 0, 22, 0, 0, 0, 0, 23, 24, - 25, 26, 86, 0, 0, 27, 0, 0, 31, 32, - 33, 34, 35, 12, 13, 0, 0, 0, 14, 15, - 16, 0, 0, 66, 296, 0, 28, 0, 29, 0, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 86, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 66, 297, 0, - 28, 0, 29, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 86, 12, 13, 0, 0, 0, 14, 15, 16, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 17, - 0, 18, 19, 20, 0, 22, 0, 0, 0, 0, - 23, 24, 25, 26, 0, 0, 0, 27, 0, 0, - 31, 32, 33, 34, 35, 12, 13, 0, 0, 0, - 14, 15, 16, 0, 0, 66, 299, 0, 28, 0, - 29, 0, 0, 17, 0, 18, 19, 20, 0, 22, - 0, 0, 0, 0, 23, 24, 25, 26, 86, 0, - 0, 27, 0, 0, 31, 32, 33, 34, 35, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 66, - 109, 0, 28, 0, 29, 0, 0, 0, 0, 0, - 0, 0, 12, 13, 0, 0, 0, 14, 15, 16, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 17, 0, 18, 19, 20, 0, 22, 0, 0, 0, - 0, 23, 24, 25, 26, 0, 0, 0, 27, 0, - 0, 31, 32, 33, 34, 35, 12, 13, 0, 0, - 0, 14, 15, 16, 66, 0, 0, 28, 0, 29, - 0, 0, 0, 0, 17, 0, 18, 19, 20, 0, - 22, 0, 0, 0, 0, 23, 24, 25, 26, 0, - 0, 0, 27, 0, 0, 31, 32, 33, 34, 35, - 12, 13, 0, 0, 0, 14, 15, 16, 0, 0, - 0, 0, 66, 0, 0, 28, 0, 29, 17, 0, - 18, 19, 20, 0, 22, 0, 0, 0, 0, 23, - 24, 25, 26, 0, 0, 0, 27, 0, 0, 31, - 32, 33, 34, 35, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 66, 0, 0, 28, 0, 29, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 12, 13, - 0, 0, 0, 14, 15, 16, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 17, 0, 18, 19, - 20, 0, 22, 0, 0, 0, 0, 23, 24, 25, - 26, 0, 0, 0, 27, 0, 0, 31, 32, 33, - 34, 35, 12, 13, 0, 0, 0, 14, 15, 16, - 66, 0, 0, 28, 0, 29, 0, 0, 0, 0, - 17, 0, 18, 19, 20, 0, 22, 0, 0, 0, - 0, 23, 24, 25, 26, 0, 0, 0, 27, 0, - 0, 31, 32, 33, 34, 35, 0, 0, 0, 0, - 0, 0, 0, 0, 66, 0, 0, 28, 0, 29, - 0, 0, 0, 116, 0, 0, 0, 12, 13, 0, - 0, 0, 14, 15, 16, 0, 0, 86, 0, 0, - 0, 0, 0, 0, 0, 17, 0, 18, 19, 20, - 0, 22, 0, 0, 0, 0, 23, 24, 25, 26, - 0, 0, 0, 27, 0, 0, 31, 32, 33, 34, - 35, 118, 0, 0, 66, 12, 13, 28, 0, 29, - 14, 15, 16, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 17, 0, 18, 19, 20, 0, 22, - 0, 0, 0, 0, 23, 24, 25, 26, 0, 0, - 0, 27, 0, 0, 31, 32, 33, 34, 35, 140, - 0, 0, 66, 12, 13, 28, 0, 29, 14, 15, - 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 103, 0, 0, - 28, 0, 29, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 213, - 0, 0, 0, 12, 13, 0, 0, 0, 14, 15, - 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 17, 0, 18, 19, 20, 0, 22, 0, 0, - 0, 0, 23, 24, 25, 26, 0, 0, 0, 27, - 0, 0, 31, 32, 33, 34, 35, 12, 13, 0, - 0, 0, 14, 15, 16, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 17, 0, 18, 19, 20, - 0, 22, 0, 0, 0, 0, 23, 24, 25, 26, - 0, 0, 0, 27, 0, 0, 31, 32, 33, 34, - 35, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 275, 0, 0, 0, 12, 13, 0, - 0, 0, 14, 15, 16, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 17, 0, 18, 19, 20, - 0, 22, 0, 0, 0, 0, 23, 24, 25, 26, - 0, 0, 0, 27, 0, 0, 31, 32, 33, 34, - 35, 0, 0, 0, 0, 12, 13, 0, 0, 0, - 14, 15, 16, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 17, 0, 18, 19, 20, 0, 22, - 0, 0, 0, 0, 23, 24, 25, 26, 0, 0, - 0, 27, 0, 0, 31, 32, 33, 34, 35, 0, - 12, 13, 67, 69, 0, 14, 15, 16, 73, 0, - 0, 0, 0, 0, 0, 0, 0, 91, 17, 0, - 18, 19, 20, 0, 22, 0, 0, 0, 0, 23, - 24, 25, 26, 0, 0, 0, 27, 0, 0, 31, - 32, 33, 34, 35, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 146, 147, 148, - 149, 150, 151, 0, 0, 0, 0, 0, 0, 91, - 0, 0, 0, 0, 91, 0, 0, 91, 91, 0, - 0, 91, 0, 91, 91, 0, 0, 0, 91, 91, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 91, - 0, 0, 0, 91, 0, 91, 91, 91, 91, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 91, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 91, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 91, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 91, 91, 91, 91, 0, 91, 0, - 91, 91, 0, 0, 0, 0, 0, 0, 91, 91, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 91, 91, 91, 91, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 91, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 91, 91, 91, 91, 91, 0, 91, 91, 91, -}; -short yycheck[] = { 41, - 0, 41, 63, 41, 37, 41, 59, 59, 63, 42, - 43, 63, 45, 63, 47, 59, 62, 41, 63, 107, - 108, 63, 40, 63, 37, 63, 123, 63, 37, 7, - 44, 223, 103, 37, 302, 303, 94, 37, 303, 123, - 40, 41, 42, 43, 44, 45, 134, 47, 313, 63, - 261, 262, 30, 41, 112, 0, 289, 123, 58, 59, - 60, 94, 62, 63, 53, 54, 40, 40, 287, 302, - 303, 59, 41, 62, 63, 44, 91, 41, 124, 112, - 44, 37, 40, 154, 123, 40, 42, 40, 60, 40, - 40, 47, 37, 93, 94, 261, 41, 42, 43, 44, - 45, 226, 47, 40, 40, 40, 60, 85, 40, 112, - 0, 303, 112, 58, 59, 60, 293, 62, 63, 41, - 41, 313, 100, 123, 124, 41, 293, 304, 305, 306, - 281, 44, 121, 41, 41, 44, 93, 41, 94, 44, - 228, 154, 41, 41, 293, 154, 40, 37, 93, 94, - 154, 41, 42, 43, 44, 45, 112, 47, 136, 137, - 40, 59, 293, 41, 261, 262, 40, 112, 58, 59, - 60, 291, 62, 63, 41, 300, 301, 302, 123, 124, - 91, 59, 59, 273, 41, 40, 272, 93, 206, 178, - 179, 41, 41, 0, 41, 320, 321, 93, 59, 59, - 325, 41, -1, 93, 94, -1, -1, 260, 261, 262, - 298, -1, 220, 41, -1, -1, 260, 261, 262, 265, - -1, -1, 112, 40, -1, -1, 43, -1, 45, 290, - 291, 59, -1, 123, 124, 290, 291, -1, 290, 291, - 290, 291, 275, 221, 222, 290, 291, -1, 290, 291, - 290, 291, 290, 291, 290, 291, -1, 257, 258, 259, - 260, 261, 262, 263, 264, 265, 290, 291, 268, 269, - 270, -1, 260, 261, 262, 275, 290, 291, -1, 268, - -1, 281, 41, 283, 284, 285, 286, 287, -1, 289, - 290, 291, 292, 293, 294, 295, 296, 297, -1, 299, - 59, 301, 302, 303, 304, 305, 306, -1, -1, -1, - 288, -1, 257, 258, 259, 260, 261, 262, 263, 264, - 265, 293, -1, 268, 269, 270, -1, 305, -1, -1, - 275, -1, 304, 305, 306, -1, 281, 41, 283, 284, - 285, 286, 287, -1, 289, 290, 291, 292, 293, 294, - 295, 296, 297, -1, 299, 59, 301, 302, 303, 304, - 305, 306, 260, 261, 262, -1, -1, 257, 258, 259, - 260, 261, 262, 263, 264, 265, -1, -1, 268, 269, - 270, 0, 260, 261, 262, 275, -1, -1, -1, -1, - 41, 281, -1, 283, 284, 285, 286, 287, -1, 289, - 290, 291, 292, 293, 294, 295, 296, 297, 59, 299, - -1, 301, 302, 303, 304, 305, 306, -1, 37, -1, - -1, 40, 41, 42, 43, 44, 45, -1, 47, -1, - -1, -1, 260, 261, 262, -1, 0, -1, 41, 58, - 59, -1, -1, 62, 63, -1, 263, 264, -1, -1, - -1, 268, 269, 270, -1, -1, 59, -1, -1, -1, - -1, -1, -1, -1, 281, -1, 283, 284, 285, -1, - 287, -1, -1, 37, 93, 94, 40, 41, 42, 43, - 44, 45, 299, 47, -1, 302, 303, 304, 305, 306, - -1, 0, -1, 112, 58, 59, 60, -1, 62, 63, - -1, 260, 261, 262, 123, 124, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 41, -1, -1, -1, 37, 93, - 94, 40, 41, 42, 43, -1, 45, -1, 47, -1, - -1, -1, 59, -1, 41, -1, -1, -1, -1, 58, - 59, 60, -1, 62, 63, -1, 260, 261, 262, 123, - 124, -1, 59, -1, -1, 62, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 93, 94, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 112, -1, -1, -1, -1, -1, 260, - 261, 262, -1, -1, 123, 124, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 124, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 257, 258, - 259, 260, 261, 262, 263, 264, 265, -1, -1, 268, - 269, 270, -1, -1, -1, -1, 275, 260, 261, 262, - -1, -1, 281, -1, 283, 284, 285, 286, 287, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, -1, - 299, -1, 301, 302, 303, 304, 305, 306, -1, -1, - -1, -1, -1, 257, 258, 259, 260, 261, 262, 263, - 264, 265, -1, -1, 268, 269, 270, -1, -1, -1, - -1, 275, -1, -1, -1, -1, -1, 281, -1, 283, - 284, 285, 286, 287, -1, 289, 290, 291, 292, 293, - 294, 295, 296, 297, -1, 299, -1, 301, 302, 303, - 304, 305, 306, 260, 261, 262, -1, -1, 257, 258, - 259, 260, 261, 262, 263, 264, 265, -1, -1, 268, - 269, 270, 0, 260, 261, 262, 275, -1, 265, -1, - -1, -1, 281, -1, 283, 284, 285, 286, 287, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, -1, - 299, -1, 301, 302, 303, 304, 305, 306, -1, 37, - -1, -1, 40, 41, 42, 43, 44, 45, -1, 47, - -1, -1, -1, -1, -1, -1, -1, 0, -1, -1, - 58, 59, 60, -1, 62, 63, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 37, 93, 94, 40, 41, 42, - 43, 44, 45, -1, 47, -1, -1, -1, -1, -1, - -1, 0, -1, -1, 112, 58, 59, 60, -1, 62, - 63, -1, -1, -1, -1, 123, 124, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 37, -1, - 93, 40, 41, 42, 43, 44, 45, -1, 47, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 58, - 59, 60, -1, 62, 63, -1, -1, -1, -1, -1, - 123, 124, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 93, 94, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 112, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 123, 124, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 257, - 258, 259, 260, 261, 262, 263, 264, 265, -1, -1, - 268, 269, 270, -1, -1, -1, -1, 275, -1, -1, - -1, -1, -1, 281, -1, 283, 284, 285, 286, 287, - -1, 289, 290, -1, 292, 293, 294, 295, 296, 297, - -1, 299, -1, 301, 302, 303, 304, 305, 306, -1, - -1, -1, -1, -1, 257, 258, 259, 260, 261, 262, - 263, 264, 265, -1, -1, 268, 269, 270, -1, -1, - -1, -1, 275, -1, 40, 41, -1, 43, 281, 45, - 283, 284, 285, 286, 287, -1, 289, 290, 291, 292, - 293, 294, 295, 296, 297, -1, 299, 63, 301, 302, - 303, 304, 305, 306, -1, -1, -1, -1, 257, 258, - 259, 260, 261, 262, 263, 264, 265, -1, -1, 268, - 269, 270, 0, -1, -1, -1, 275, -1, -1, -1, - -1, -1, 281, -1, 283, 284, 285, 286, 287, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, -1, - 299, -1, 301, -1, -1, 304, 305, 306, -1, 37, - -1, -1, 40, 41, 42, 43, 44, 45, -1, 47, - -1, -1, -1, -1, -1, -1, 0, -1, -1, -1, - 58, 59, 60, -1, 62, 63, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 37, -1, 93, 40, 41, 42, 43, - 44, 45, -1, 47, -1, -1, -1, -1, -1, -1, - 0, -1, -1, -1, 58, 59, 60, -1, 62, 63, - -1, -1, -1, -1, -1, 123, 124, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 37, -1, 93, - 40, 41, 42, 43, 44, 45, -1, 47, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 58, 59, - 60, -1, 62, 63, -1, -1, -1, 263, 264, 123, - 124, -1, 268, 269, 270, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 281, -1, 283, 284, 285, - -1, 287, -1, 93, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 123, 124, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 257, - 258, 259, 260, 261, 262, 263, 264, 265, -1, -1, - 268, 269, 270, -1, -1, -1, -1, 275, -1, -1, - -1, -1, -1, 281, -1, 283, 284, 285, 286, 287, - -1, 289, 290, 291, 292, 293, 294, 295, 296, 297, - -1, 299, -1, 301, 302, 303, 304, 305, 306, -1, - -1, -1, -1, 257, 258, 259, 260, 261, 262, 263, - 264, 265, -1, -1, 268, 269, 270, -1, -1, -1, - -1, 275, -1, 40, -1, -1, 43, 281, 45, 283, - 284, 285, 286, 287, -1, 289, 290, 291, 292, 293, - 294, 295, 296, 297, -1, 299, -1, 301, 302, 303, - 304, 305, 306, -1, -1, -1, -1, 257, 258, 259, - 260, 261, 262, 263, 264, 265, -1, -1, 268, 269, - 270, 0, -1, -1, -1, 275, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, 286, 287, -1, 289, - 290, 291, 292, 293, 294, 295, 296, 297, -1, 299, - -1, 301, 302, 303, 304, 305, 306, -1, 37, -1, - -1, 40, 41, 42, 43, 44, 45, -1, 47, -1, - -1, -1, -1, -1, -1, 0, -1, -1, -1, 58, - 59, 60, -1, 62, 63, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 37, -1, 93, 40, 41, 42, 43, 44, - 45, -1, 47, -1, -1, -1, -1, -1, -1, 0, - -1, -1, -1, 58, 59, 60, -1, 62, 63, -1, - -1, -1, -1, -1, 123, 124, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 37, -1, 93, 40, - 41, 42, 43, 44, 45, -1, 47, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 58, 59, 60, - -1, 62, 63, -1, 261, 262, 263, 264, 123, 124, - -1, 268, 269, 270, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 281, -1, 283, 284, 285, -1, - 287, -1, 93, 94, -1, 292, 293, 294, 295, -1, - -1, -1, 299, -1, -1, 302, 303, 304, 305, 306, - -1, 112, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 123, 124, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 257, 258, - 259, 260, 261, 262, 263, 264, 265, -1, -1, 268, - 269, 270, -1, -1, -1, -1, 275, -1, -1, -1, - -1, -1, 281, -1, 283, 284, 285, 286, 287, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, -1, - 299, -1, 301, 302, 303, 304, 305, 306, -1, -1, - -1, -1, 257, 258, 259, 260, 261, 262, 263, 264, - 265, -1, -1, 268, 269, 270, -1, -1, -1, -1, - 275, -1, -1, -1, -1, -1, 281, -1, 283, 284, - 285, 286, 287, -1, 289, 290, 291, 292, 293, 294, - 295, 296, 297, -1, 299, -1, 301, 302, 303, 304, - 305, 306, -1, -1, -1, -1, 257, 258, 259, 260, - 261, 262, 263, 264, 265, -1, -1, 268, 269, 270, - 0, -1, -1, -1, 275, -1, -1, -1, -1, -1, - 281, -1, 283, 284, 285, 286, 287, -1, -1, 290, - 291, 292, 293, 294, 295, 296, 297, -1, 299, -1, - 301, -1, -1, 304, 305, 306, -1, 37, -1, -1, - 40, 41, 42, 43, 44, 45, -1, 47, -1, -1, - -1, -1, -1, -1, -1, 0, -1, -1, 58, 59, - 60, -1, 62, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 93, 94, 40, 41, -1, 43, 44, - 45, -1, -1, -1, -1, -1, 0, -1, -1, -1, - -1, -1, 112, 58, 59, 60, -1, 62, 63, -1, - -1, -1, -1, 123, 124, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 40, 41, 93, 43, - 44, 45, -1, -1, -1, -1, 0, -1, -1, -1, - -1, -1, -1, -1, 58, 59, 60, -1, 62, 63, - -1, -1, -1, -1, -1, -1, -1, -1, 123, 124, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 40, 41, -1, 93, - 44, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 58, 59, 60, -1, 62, 63, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 123, - 124, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 40, -1, 93, - 43, -1, 45, -1, -1, -1, -1, 257, 258, 259, - 260, 261, 262, 263, 264, 265, -1, -1, 268, 269, - 270, -1, -1, -1, -1, 275, -1, -1, -1, 123, - 124, 281, -1, 283, 284, 285, 286, 287, -1, 289, - -1, -1, 292, 293, 294, 295, 296, 297, -1, 299, - -1, 301, 302, 303, 304, 305, 306, -1, -1, -1, - -1, -1, 257, 258, 259, 260, 261, 262, 263, 264, - 265, -1, -1, 268, 269, 270, -1, -1, -1, -1, - 275, -1, -1, -1, -1, -1, 281, -1, 283, 284, - 285, 286, 287, -1, 289, 290, 291, 292, 293, 294, - 295, 296, 297, -1, 299, -1, 301, 302, 303, 304, - 305, 306, -1, 257, 258, 259, 260, 261, 262, 263, - 264, 265, -1, -1, 268, 269, 270, -1, -1, -1, - -1, 275, -1, -1, -1, -1, -1, 281, -1, 283, - 284, 285, 286, 287, -1, 289, 290, 291, 292, 293, - 294, 295, 296, 297, -1, 299, -1, 301, 302, 303, - 304, 305, 306, 257, 258, 259, 260, 261, 262, 263, - 264, 265, -1, 0, 268, 269, 270, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 281, -1, 283, - 284, 285, 286, 287, -1, 289, 290, 291, 292, 293, - 294, 295, 296, 297, -1, 299, -1, 301, 302, 303, - 304, 305, 306, 40, 41, -1, 259, 44, 261, 262, - 263, 264, -1, -1, 0, 268, 269, 270, -1, -1, - -1, 58, 59, 60, -1, 62, 63, -1, 281, -1, - 283, 284, 285, -1, 287, -1, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, 301, 302, - 303, 304, 305, 306, 40, -1, 93, 43, -1, 45, - -1, -1, -1, -1, 0, -1, -1, -1, -1, -1, - -1, -1, -1, 59, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 123, 124, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 40, -1, -1, 43, -1, 45, - -1, -1, -1, -1, 0, -1, -1, -1, -1, -1, - -1, -1, -1, 59, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 123, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 40, -1, -1, 43, -1, 45, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 0, -1, -1, 59, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 123, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 40, -1, -1, 43, -1, 45, -1, -1, -1, -1, - 257, 258, 259, 260, 261, 262, 263, 264, 265, 59, - -1, 268, 269, 270, -1, -1, -1, 123, -1, -1, - -1, -1, -1, -1, 281, -1, 283, 284, 285, 286, - 287, -1, 289, 290, 291, 292, 293, 294, 295, 296, - 297, -1, 299, -1, 301, 302, 303, 304, 305, 306, - -1, 257, 258, 259, 260, 261, 262, 263, 264, -1, - -1, -1, 268, 269, 270, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 281, -1, 283, 284, 285, - 286, 287, -1, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, 301, 302, 303, 304, 305, - 306, 257, 258, 259, 260, 261, 262, 263, 264, -1, - -1, -1, 268, 269, 270, 40, -1, -1, 43, -1, - 45, -1, -1, -1, -1, 281, -1, 283, 284, 285, - 286, 287, -1, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, 301, 302, 303, 304, 305, - 306, 257, 258, 259, 260, -1, 262, 263, 264, -1, - -1, 0, 268, 269, 270, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 281, -1, 283, 284, 285, - 286, 287, -1, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, 301, 302, 303, 304, 305, - 306, 40, -1, -1, 43, -1, 45, 257, 258, 259, - 260, 261, 262, 263, 264, -1, -1, 0, 268, 269, - 270, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, 286, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, 301, 302, 303, 304, 305, 306, 40, -1, -1, - 43, -1, 45, -1, -1, -1, -1, 0, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 123, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 40, -1, -1, - 43, -1, 45, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 263, 264, - 123, 266, 267, 268, 269, 270, -1, -1, -1, -1, - -1, 276, 277, 278, 279, 280, 281, -1, 283, 284, - 285, -1, 287, 288, -1, -1, -1, 292, 293, 294, - 295, -1, -1, -1, 299, -1, -1, 302, 303, 304, - 305, 306, -1, -1, -1, -1, -1, -1, -1, -1, - 123, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 257, 258, - 259, -1, -1, -1, 263, 264, -1, -1, -1, 268, - 269, 270, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 281, -1, 283, 284, 285, 286, 287, -1, - -1, -1, -1, 292, 293, 294, 295, -1, -1, -1, - 299, -1, 301, 302, 303, 304, 305, 306, -1, -1, - -1, -1, -1, -1, 257, 258, 259, -1, -1, -1, - 263, 264, -1, -1, -1, 268, 269, 270, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 281, -1, - 283, 284, 285, 286, 287, -1, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, 301, 302, - 303, 304, 305, 306, 257, 258, 259, -1, -1, -1, - 263, 264, -1, -1, -1, 268, 269, 270, 0, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 281, -1, - 283, 284, 285, 286, 287, -1, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, 301, 302, - 303, 304, 305, 306, -1, 37, -1, -1, 40, 41, - 42, 43, 44, 45, -1, 47, -1, -1, -1, -1, - -1, -1, -1, 0, -1, -1, 58, 59, 60, -1, - 62, 63, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 37, 93, 94, 40, 41, 42, 43, 44, 45, -1, - 47, 0, -1, -1, -1, -1, -1, -1, -1, -1, - 112, 58, 59, -1, -1, 62, 63, -1, -1, -1, - -1, 123, 124, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 37, -1, - -1, -1, 41, 42, -1, 44, 93, 94, 47, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 58, - 59, 60, -1, 62, 63, 112, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 123, 124, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 93, 94, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 112, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 123, 124, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 257, 258, 259, 260, 261, - 262, 263, 264, 265, -1, -1, 268, 269, 270, -1, - -1, -1, -1, 275, -1, -1, -1, -1, -1, 281, - -1, 283, 284, 285, 286, 287, -1, 289, 290, 291, - 292, -1, 294, 295, 296, 297, -1, 299, -1, 301, - 302, 303, -1, -1, -1, -1, -1, -1, -1, -1, - 257, 258, 259, 260, 261, 262, 263, 264, 265, -1, - -1, 268, 269, 270, -1, -1, -1, -1, 275, -1, - -1, -1, -1, -1, 281, -1, 283, 284, 285, 286, - 287, 0, 289, 290, 291, 292, -1, 294, 295, 296, - 297, -1, 299, -1, 301, 302, 303, -1, 257, 258, - 259, 260, 261, 262, -1, -1, 265, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 275, -1, 37, -1, - -1, -1, 41, 42, -1, 44, 0, 286, 47, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, 58, - 59, 60, 301, 62, 63, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 37, -1, -1, -1, 41, 42, -1, - 44, 0, -1, 47, 93, 94, -1, -1, -1, -1, - -1, -1, -1, -1, 58, 59, 60, -1, 62, 63, - -1, -1, -1, 112, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 123, 124, -1, -1, 37, -1, - -1, -1, 41, 42, -1, 44, -1, -1, 47, 93, - 94, -1, -1, -1, -1, -1, -1, -1, -1, 58, - 59, 60, -1, 62, 63, -1, -1, -1, 112, -1, - 0, -1, -1, -1, -1, -1, -1, -1, -1, 123, - 124, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 93, 94, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 37, -1, -1, - -1, 41, 42, 112, 44, -1, -1, 47, -1, -1, - -1, -1, -1, -1, 123, 124, -1, -1, 58, 59, - 60, -1, 62, 63, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 93, 94, -1, -1, -1, 257, 258, - 259, 260, 261, 262, -1, -1, 265, -1, -1, -1, - -1, -1, 112, -1, -1, -1, 275, -1, -1, -1, - -1, -1, -1, 123, 124, -1, -1, 286, -1, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, -1, - -1, -1, 301, 257, 258, 259, 260, 261, 262, -1, - 40, 265, -1, 43, 44, 45, -1, -1, -1, -1, - -1, 275, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 286, 63, -1, 289, 290, 291, 292, 293, - 294, 295, 296, 297, -1, -1, -1, 301, 257, 258, - 259, 260, 261, 262, -1, -1, 265, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 275, -1, -1, 0, - -1, -1, -1, -1, -1, -1, -1, 286, -1, -1, - 289, 290, 291, 292, 293, 294, 295, 296, 297, -1, - -1, -1, 301, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 37, -1, -1, -1, - 41, 42, -1, 44, -1, -1, 47, 257, 258, 259, - 260, 261, 262, -1, -1, 265, -1, 58, 59, 60, - -1, 62, 63, -1, -1, 275, 0, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 286, -1, -1, 289, - 290, 291, 292, 293, 294, 295, 296, 297, -1, -1, - -1, 301, 93, 94, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 37, -1, -1, -1, 41, 42, -1, - 44, 112, -1, 47, 0, -1, -1, -1, -1, -1, - -1, -1, 123, 124, 58, 59, 60, -1, 62, 63, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 37, -1, -1, -1, 41, 42, -1, 44, 93, - 94, 47, -1, 263, 264, -1, -1, -1, 268, 269, - 270, -1, 58, 59, 60, -1, 62, -1, 112, -1, - -1, 281, -1, 283, 284, 285, 0, 287, -1, 123, - 124, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, 93, 94, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 37, -1, -1, 112, 41, 42, -1, - 44, -1, -1, 47, -1, -1, -1, 123, 124, -1, - -1, -1, -1, -1, 58, 59, 60, -1, 62, -1, - -1, -1, -1, -1, -1, -1, 257, 258, 259, 260, - 261, 262, -1, -1, 265, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 275, 0, -1, -1, -1, 93, - 94, -1, -1, -1, -1, 286, -1, -1, 289, 290, - 291, 292, 293, 294, 295, 296, 297, -1, 112, -1, - 301, -1, -1, -1, -1, -1, -1, -1, -1, 123, - 124, -1, 37, -1, -1, -1, 41, 42, -1, 44, - -1, -1, 47, 257, 258, 259, 260, 261, 262, -1, - -1, 265, -1, 58, 59, 60, -1, 62, -1, -1, - -1, 275, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 286, -1, -1, 289, 290, 291, -1, -1, - -1, -1, 296, 297, -1, -1, -1, 301, 93, 94, - -1, 257, 258, 259, 260, 261, 262, 0, -1, 265, - -1, -1, -1, -1, -1, -1, -1, 112, -1, 275, - -1, -1, -1, -1, -1, -1, -1, -1, 123, 124, - 286, -1, -1, 289, 290, 291, -1, -1, -1, -1, - 296, 297, -1, -1, 37, 301, -1, -1, 41, 42, - -1, 44, -1, -1, 47, -1, -1, -1, -1, -1, - -1, -1, 0, -1, -1, 58, 59, 60, -1, 62, - -1, -1, -1, 257, 258, 259, 260, 261, 262, -1, - -1, 265, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 275, -1, -1, -1, -1, -1, -1, -1, 37, - 93, 94, 286, 41, 42, 289, 290, 291, -1, 47, - 0, -1, 296, 297, -1, -1, -1, 301, -1, 112, - 58, 59, 60, -1, 62, -1, -1, -1, -1, -1, - 123, 124, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 37, -1, -1, - -1, 41, 42, -1, 44, 93, 94, 47, -1, -1, - -1, -1, 257, 258, 259, 260, 261, 262, 58, 59, - 265, -1, -1, -1, 112, -1, -1, -1, -1, -1, - 275, -1, -1, -1, -1, 123, 124, -1, -1, -1, - -1, 286, -1, -1, 289, 290, 291, -1, -1, -1, - -1, 296, 297, 93, 94, -1, 301, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 112, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 123, 124, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 257, 258, 259, 260, 261, 262, - -1, -1, 265, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 275, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 286, -1, -1, 289, 290, 291, -1, - -1, -1, -1, 296, 297, -1, -1, -1, 301, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 257, - 258, 259, 260, 261, 262, -1, -1, 265, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 275, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 286, -1, - -1, 289, 290, 291, -1, -1, -1, -1, 296, 297, - -1, 7, -1, 301, -1, -1, -1, 257, 258, 259, - 260, 261, 262, -1, -1, 265, -1, -1, -1, -1, - -1, -1, -1, -1, 30, 275, -1, -1, -1, -1, - -1, 37, -1, -1, -1, -1, 286, -1, -1, 289, - 290, 291, -1, 49, -1, -1, 52, 53, 54, 55, - 56, 301, 58, 59, 60, -1, 62, 63, 64, 65, - 66, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 82, -1, -1, 85, - 86, 87, 88, 89, 90, -1, 50, 51, -1, -1, - -1, -1, -1, -1, 100, -1, -1, 103, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 115, - -1, -1, -1, -1, -1, 121, -1, 81, -1, 83, - 84, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 136, 137, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 154, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 166, 167, 168, 169, 170, -1, -1, -1, -1, 175, - 176, -1, 178, 179, -1, -1, -1, 183, -1, -1, - -1, 187, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 198, 157, 158, 201, -1, -1, 204, 205, - -1, -1, -1, -1, -1, -1, -1, -1, 17, -1, - -1, -1, -1, 177, -1, 221, 222, 223, -1, 28, - 29, -1, 31, 32, 188, 34, 190, -1, 192, -1, - -1, -1, -1, -1, 43, -1, 242, -1, 244, -1, - 246, -1, 248, -1, 250, -1, -1, -1, -1, 255, - -1, 215, -1, -1, 260, 261, 40, -1, -1, 43, - -1, 45, 268, -1, -1, -1, 230, 231, 232, 233, - 234, -1, -1, -1, -1, 59, -1, -1, -1, -1, - -1, -1, 288, -1, 93, 94, 95, 96, 97, 98, - -1, -1, -1, -1, -1, -1, 105, -1, -1, 305, - -1, 110, -1, -1, 113, 114, -1, -1, 117, 40, - 119, 120, 43, -1, 45, 124, 125, 281, -1, -1, - -1, 285, 286, 287, -1, -1, 135, 291, 59, -1, - 139, -1, 141, 142, 143, 144, -1, -1, -1, 123, - -1, -1, -1, 152, -1, -1, 155, -1, -1, -1, - -1, -1, 316, 317, -1, -1, 165, 40, 322, -1, - 43, -1, 45, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 59, -1, -1, -1, - -1, -1, -1, -1, 193, -1, -1, -1, -1, -1, - -1, -1, 123, -1, 125, -1, -1, -1, -1, -1, - 209, 210, 211, 212, -1, 214, -1, 216, 217, -1, - -1, -1, -1, -1, -1, 224, 225, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 236, 237, 238, - 239, 40, -1, -1, 43, -1, 45, -1, -1, -1, - 123, -1, 125, -1, -1, -1, -1, -1, -1, -1, - 59, -1, -1, -1, -1, 264, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 276, 277, 278, - 279, 280, -1, 282, 283, 284, 260, 261, 262, 263, - 264, -1, 266, 267, 268, 269, 270, 271, -1, 273, - 274, -1, 276, 277, 278, 279, 280, 281, 282, 283, - 284, 285, -1, 287, 288, -1, -1, -1, 292, 293, - 294, 295, -1, -1, 123, 299, 125, -1, 302, 303, - 304, 305, 306, -1, -1, -1, -1, -1, -1, 260, - -1, -1, 263, 264, -1, 266, 267, 268, 269, 270, - 271, 272, 273, 274, -1, 276, 277, 278, 279, 280, - 281, 282, 283, 284, 285, -1, 287, 288, -1, -1, - -1, 292, 293, 294, 295, -1, -1, -1, 299, -1, - -1, 302, 303, 304, 305, 306, -1, 260, -1, -1, - 263, 264, -1, 266, 267, 268, 269, 270, 271, 272, - 273, 274, -1, 276, 277, 278, 279, 280, 281, 282, - 283, 284, 285, -1, 287, 288, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, -1, 302, - 303, 304, 305, 306, 40, -1, -1, 43, -1, 45, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 59, -1, -1, -1, -1, -1, -1, - -1, 260, -1, -1, 263, 264, -1, 266, 267, 268, - 269, 270, 271, 272, 273, 274, -1, 276, 277, 278, - 279, 280, 281, 282, 283, 284, 285, -1, 287, 288, - -1, -1, -1, 292, 293, 294, 295, -1, -1, -1, - 299, -1, -1, 302, 303, 304, 305, 306, 40, -1, - -1, 43, -1, 45, -1, -1, -1, 123, -1, 125, - -1, -1, -1, -1, -1, -1, -1, 59, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 40, -1, -1, 43, -1, - 45, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 59, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 123, -1, 125, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 40, -1, -1, - 43, -1, 45, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 59, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 123, -1, - 125, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 260, -1, -1, 263, 264, -1, - 266, 267, 268, 269, 270, 271, 272, 273, 274, -1, - 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, - -1, 287, 288, -1, -1, -1, 292, 293, 294, 295, - 123, -1, 125, 299, -1, -1, 302, 303, 304, 305, - 306, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 40, 41, -1, 43, 44, 45, -1, -1, 260, -1, - -1, 263, 264, -1, 266, 267, 268, 269, 270, 271, - 272, 273, 274, 63, 276, 277, 278, 279, 280, 281, - 282, 283, 284, 285, -1, 287, 288, -1, -1, -1, - 292, 293, 294, 295, -1, -1, -1, 299, -1, -1, - 302, 303, 304, 305, 306, 260, -1, -1, 263, 264, - -1, 266, 267, 268, 269, 270, 271, 272, 273, 274, - -1, 276, 277, 278, 279, 280, 281, 282, 283, 284, - 285, -1, 287, 288, -1, -1, -1, 292, 293, 294, - 295, -1, -1, -1, 299, -1, -1, 302, 303, 304, - 305, 306, -1, 40, -1, -1, 43, 260, 45, -1, - 263, 264, -1, 266, 267, 268, 269, 270, 271, 272, - 273, 274, 59, 276, 277, 278, 279, 280, 281, 282, - 283, 284, 285, -1, 287, 288, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, -1, 302, - 303, 304, 305, 306, 40, -1, -1, 43, -1, 45, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 59, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 123, -1, 125, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 40, -1, -1, 43, -1, 45, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 59, -1, -1, 263, 264, -1, -1, -1, 268, 269, - 270, -1, -1, -1, -1, -1, -1, 123, -1, 125, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, -1, -1, 40, - -1, -1, 43, -1, 45, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 123, -1, 125, -1, 59, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 260, -1, -1, 263, 264, -1, 266, - 267, 268, 269, 270, 271, 272, 273, 274, -1, 276, - 277, 278, 279, 280, 281, 282, 283, 284, 285, -1, - 287, 288, 123, -1, 125, 292, 293, 294, 295, -1, - -1, -1, 299, -1, -1, 302, 303, 304, 305, 306, - -1, -1, -1, -1, 260, -1, -1, 263, 264, -1, - 266, 267, 268, 269, 270, 271, -1, 273, 274, -1, - 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, - -1, 287, 288, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, 260, -1, -1, 263, 264, -1, 266, 267, 268, - 269, 270, 271, -1, 273, 274, -1, 276, 277, 278, - 279, 280, 281, 282, 283, 284, 285, -1, 287, 288, - -1, -1, -1, 292, 293, 294, 295, -1, -1, -1, - 299, -1, -1, 302, 303, 304, 305, 306, 40, -1, - -1, 43, -1, 45, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 59, -1, 260, - -1, -1, 263, 264, -1, 266, 267, 268, 269, 270, - 271, -1, 273, 274, -1, 276, 277, 278, 279, 280, - 281, 282, 283, 284, 285, -1, 287, 288, -1, -1, - -1, 292, 293, 294, 295, -1, -1, -1, 299, -1, - -1, 302, 303, 304, 305, 306, 40, -1, -1, 43, - -1, 45, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 123, -1, 125, -1, 59, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 40, -1, -1, 43, -1, 45, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 59, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 123, - -1, 125, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 40, -1, -1, 43, -1, 45, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 59, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 123, -1, 125, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 260, -1, - -1, 263, 264, -1, 266, 267, 268, 269, 270, 271, - -1, 273, 274, -1, 276, 277, 278, 279, 280, 281, - 282, 283, 284, 285, -1, 287, 288, 123, -1, 125, - 292, 293, 294, 295, -1, -1, -1, 299, -1, -1, - 302, 303, 304, 305, 306, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 40, - -1, -1, 43, -1, 45, -1, 260, -1, -1, 263, - 264, -1, 266, 267, 268, 269, 270, 271, 59, 273, - 274, -1, 276, 277, 278, 279, 280, 281, 282, 283, - 284, 285, -1, 287, 288, -1, -1, -1, 292, 293, - 294, 295, -1, -1, -1, 299, -1, -1, 302, 303, - 304, 305, 306, 260, -1, -1, 263, 264, -1, 266, - 267, 268, 269, 270, 271, -1, 273, 274, -1, 276, - 277, 278, 279, 280, 281, 282, 283, 284, 285, -1, - 287, 288, 123, -1, 125, 292, 293, 294, 295, -1, - -1, -1, 299, -1, -1, 302, 303, 304, 305, 306, - 40, -1, -1, 43, 260, 45, -1, 263, 264, -1, - 266, 267, 268, 269, 270, 271, -1, 273, 274, -1, - 276, 277, 278, 279, 280, 281, 282, 283, 284, 285, - -1, 287, 288, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, 40, -1, -1, 43, 44, 45, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 60, -1, 62, 63, -1, -1, -1, -1, -1, - -1, -1, -1, 123, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 40, -1, -1, 43, -1, - 45, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 60, -1, 62, 63, 260, - -1, -1, 263, 264, -1, 266, 267, 268, 269, 270, - 271, -1, 273, 274, -1, 276, 277, 278, 279, 280, - 281, 282, 283, 284, 285, -1, 287, 288, -1, -1, - -1, 292, 293, 294, 295, -1, -1, -1, 299, -1, - -1, 302, 303, 304, 305, 306, 40, 41, -1, 43, - 44, 45, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 63, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 40, 41, -1, 43, 44, 45, -1, 257, 258, 259, - -1, -1, -1, 263, 264, -1, -1, -1, 268, 269, - 270, -1, -1, 63, -1, -1, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, 286, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, 301, 302, 303, 304, 305, 306, 40, 41, -1, - 43, 44, 45, -1, 263, 264, -1, -1, -1, 268, - 269, 270, -1, -1, -1, -1, -1, -1, -1, -1, - 63, -1, 281, -1, 283, 284, 285, -1, 287, -1, - -1, -1, -1, 292, 293, 294, 295, 296, 297, -1, - 299, -1, -1, 302, 303, 304, 305, 306, 263, 264, - -1, -1, -1, 268, 269, 270, -1, -1, -1, -1, - 40, 41, -1, 43, 44, 45, 281, -1, 283, 284, - 285, -1, 287, -1, -1, -1, -1, 292, 293, 294, - 295, 296, 297, 63, 299, -1, -1, 302, 303, 304, - 305, 306, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 40, -1, - -1, 43, -1, 45, -1, -1, -1, -1, -1, 263, - 264, -1, -1, -1, 268, 269, 270, 59, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 281, -1, 283, - 284, 285, -1, 287, -1, -1, -1, -1, 292, 293, - 294, 295, -1, -1, -1, 299, -1, -1, 302, 303, - 304, 305, 306, 263, 264, -1, -1, -1, 268, 269, - 270, 40, -1, -1, 43, -1, 45, -1, -1, -1, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 40, - 263, 264, 43, -1, 45, 268, 269, 270, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 281, -1, - 283, 284, 285, -1, 287, -1, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, -1, 302, - 303, 304, 305, 306, 40, -1, -1, 43, 44, 45, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 263, 264, -1, -1, 63, 268, 269, - 270, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, 259, -1, -1, - -1, 263, 264, -1, -1, -1, 268, 269, 270, -1, - -1, 40, -1, -1, 43, 44, 45, -1, -1, 281, - -1, 283, 284, 285, -1, 287, -1, -1, -1, -1, - 292, 293, 294, 295, 63, -1, -1, 299, -1, 301, - 302, 303, 304, 305, 306, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 40, -1, - 259, 43, 44, 45, 263, 264, -1, -1, -1, 268, - 269, 270, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 63, 281, -1, 283, 284, 285, -1, 287, -1, - -1, -1, -1, 292, 293, 294, 295, -1, -1, -1, - 299, -1, 301, 302, 303, 304, 305, 306, 259, -1, - -1, -1, 263, 264, -1, -1, -1, 268, 269, 270, - -1, -1, 40, -1, -1, 43, 44, 45, -1, -1, - 281, -1, 283, 284, 285, -1, 287, -1, -1, -1, - -1, 292, 293, 294, 295, 63, -1, -1, 299, -1, - 301, 302, 303, 304, 305, 306, -1, 263, 264, -1, - -1, -1, 268, 269, 270, -1, -1, 40, -1, -1, - 43, 44, 45, -1, -1, 281, -1, 283, 284, 285, - -1, 287, -1, -1, -1, -1, 292, 293, 294, 295, - 63, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 40, -1, -1, 43, 44, 45, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, 263, 264, 63, -1, -1, 268, - 269, 270, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 281, -1, 283, 284, 285, -1, 287, -1, - -1, -1, -1, 292, 293, 294, 295, -1, -1, -1, - 299, -1, -1, 302, 303, 304, 305, 306, -1, -1, - -1, 263, 264, -1, -1, -1, 268, 269, 270, -1, - -1, 40, -1, -1, 43, -1, 45, -1, -1, 281, - -1, 283, 284, 285, -1, 287, -1, -1, -1, 58, - 292, 293, 294, 295, 63, -1, -1, 299, -1, -1, - 302, 303, 304, 305, 306, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 40, -1, -1, 43, -1, - 45, -1, -1, -1, -1, 263, 264, -1, -1, -1, - 268, 269, 270, 58, -1, -1, -1, -1, 63, -1, - -1, -1, -1, 281, -1, 283, 284, 285, -1, 287, - -1, -1, -1, -1, 292, 293, 294, 295, -1, -1, - -1, 299, -1, -1, 302, 303, 304, 305, 306, -1, - 263, 264, -1, -1, -1, 268, 269, 270, -1, -1, - 40, 41, -1, 43, -1, 45, -1, -1, 281, -1, - 283, 284, 285, -1, 287, -1, -1, -1, -1, 292, - 293, 294, 295, 63, -1, -1, 299, -1, -1, 302, - 303, 304, 305, 306, -1, -1, 263, 264, -1, -1, - -1, 268, 269, 270, -1, -1, 40, 41, -1, 43, - -1, 45, -1, -1, 281, -1, 283, 284, 285, -1, - 287, -1, -1, -1, -1, 292, 293, 294, 295, 63, - -1, -1, 299, -1, -1, 302, 303, 304, 305, 306, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 40, 41, -1, 43, -1, 45, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 63, 263, 264, -1, -1, -1, 268, - 269, 270, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 281, -1, 283, 284, 285, -1, 287, -1, - -1, -1, -1, 292, 293, 294, 295, -1, -1, -1, - 299, -1, -1, 302, 303, 304, 305, 306, 263, 264, - -1, -1, -1, 268, 269, 270, -1, -1, 40, 41, - -1, 43, -1, 45, -1, -1, 281, -1, 283, 284, - 285, -1, 287, -1, -1, -1, -1, 292, 293, 294, - 295, 63, -1, -1, 299, -1, -1, 302, 303, 304, - 305, 306, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, 40, 41, -1, 43, -1, 45, -1, -1, - -1, -1, -1, 263, 264, -1, -1, -1, 268, 269, - 270, -1, -1, -1, -1, 63, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, -1, -1, 263, - 264, -1, -1, -1, 268, 269, 270, -1, -1, 40, - 41, -1, 43, -1, 45, -1, -1, 281, -1, 283, - 284, 285, -1, 287, -1, -1, -1, -1, 292, 293, - 294, 295, 63, -1, -1, 299, -1, -1, 302, 303, - 304, 305, 306, 263, 264, -1, -1, -1, 268, 269, - 270, -1, -1, 40, 41, -1, 43, -1, 45, -1, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, 63, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 40, 41, -1, - 43, -1, 45, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 63, 263, 264, -1, -1, -1, 268, 269, 270, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 281, - -1, 283, 284, 285, -1, 287, -1, -1, -1, -1, - 292, 293, 294, 295, -1, -1, -1, 299, -1, -1, - 302, 303, 304, 305, 306, 263, 264, -1, -1, -1, - 268, 269, 270, -1, -1, 40, 41, -1, 43, -1, - 45, -1, -1, 281, -1, 283, 284, 285, -1, 287, - -1, -1, -1, -1, 292, 293, 294, 295, 63, -1, - -1, 299, -1, -1, 302, 303, 304, 305, 306, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 40, - 41, -1, 43, -1, 45, -1, -1, -1, -1, -1, - -1, -1, 263, 264, -1, -1, -1, 268, 269, 270, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 281, -1, 283, 284, 285, -1, 287, -1, -1, -1, - -1, 292, 293, 294, 295, -1, -1, -1, 299, -1, - -1, 302, 303, 304, 305, 306, 263, 264, -1, -1, - -1, 268, 269, 270, 40, -1, -1, 43, -1, 45, - -1, -1, -1, -1, 281, -1, 283, 284, 285, -1, - 287, -1, -1, -1, -1, 292, 293, 294, 295, -1, - -1, -1, 299, -1, -1, 302, 303, 304, 305, 306, - 263, 264, -1, -1, -1, 268, 269, 270, -1, -1, - -1, -1, 40, -1, -1, 43, -1, 45, 281, -1, - 283, 284, 285, -1, 287, -1, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, -1, 302, - 303, 304, 305, 306, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 40, -1, -1, 43, -1, 45, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 263, 264, - -1, -1, -1, 268, 269, 270, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 281, -1, 283, 284, - 285, -1, 287, -1, -1, -1, -1, 292, 293, 294, - 295, -1, -1, -1, 299, -1, -1, 302, 303, 304, - 305, 306, 263, 264, -1, -1, -1, 268, 269, 270, - 40, -1, -1, 43, -1, 45, -1, -1, -1, -1, - 281, -1, 283, 284, 285, -1, 287, -1, -1, -1, - -1, 292, 293, 294, 295, -1, -1, -1, 299, -1, - -1, 302, 303, 304, 305, 306, -1, -1, -1, -1, - -1, -1, -1, -1, 40, -1, -1, 43, -1, 45, - -1, -1, -1, 259, -1, -1, -1, 263, 264, -1, - -1, -1, 268, 269, 270, -1, -1, 63, -1, -1, - -1, -1, -1, -1, -1, 281, -1, 283, 284, 285, - -1, 287, -1, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, 259, -1, -1, 40, 263, 264, 43, -1, 45, - 268, 269, 270, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 281, -1, 283, 284, 285, -1, 287, - -1, -1, -1, -1, 292, 293, 294, 295, -1, -1, - -1, 299, -1, -1, 302, 303, 304, 305, 306, 259, - -1, -1, 40, 263, 264, 43, -1, 45, 268, 269, - 270, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, 40, -1, -1, - 43, -1, 45, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 259, - -1, -1, -1, 263, 264, -1, -1, -1, 268, 269, - 270, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, 281, -1, 283, 284, 285, -1, 287, -1, -1, - -1, -1, 292, 293, 294, 295, -1, -1, -1, 299, - -1, -1, 302, 303, 304, 305, 306, 263, 264, -1, - -1, -1, 268, 269, 270, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 281, -1, 283, 284, 285, - -1, 287, -1, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 259, -1, -1, -1, 263, 264, -1, - -1, -1, 268, 269, 270, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 281, -1, 283, 284, 285, - -1, 287, -1, -1, -1, -1, 292, 293, 294, 295, - -1, -1, -1, 299, -1, -1, 302, 303, 304, 305, - 306, -1, -1, -1, -1, 263, 264, -1, -1, -1, - 268, 269, 270, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 281, -1, 283, 284, 285, -1, 287, - -1, -1, -1, -1, 292, 293, 294, 295, -1, -1, - -1, 299, -1, -1, 302, 303, 304, 305, 306, -1, - 263, 264, 28, 29, -1, 268, 269, 270, 34, -1, - -1, -1, -1, -1, -1, -1, -1, 43, 281, -1, - 283, 284, 285, -1, 287, -1, -1, -1, -1, 292, - 293, 294, 295, -1, -1, -1, 299, -1, -1, 302, - 303, 304, 305, 306, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 93, 94, 95, - 96, 97, 98, -1, -1, -1, -1, -1, -1, 105, - -1, -1, -1, -1, 110, -1, -1, 113, 114, -1, - -1, 117, -1, 119, 120, -1, -1, -1, 124, 125, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 135, - -1, -1, -1, 139, -1, 141, 142, 143, 144, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 155, - -1, -1, -1, -1, -1, -1, -1, -1, -1, 165, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 193, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, 209, 210, 211, 212, -1, 214, -1, - 216, 217, -1, -1, -1, -1, -1, -1, 224, 225, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 236, 237, 238, 239, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 264, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - 276, 277, 278, 279, 280, -1, 282, 283, 284, -}; -#define YYFINAL 1 -#ifndef YYDEBUG -#define YYDEBUG 0 -#endif -#define YYMAXTOKEN 306 -#if YYDEBUG -const char *yyname[] = { -"end-of-file",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, -0,0,0,"'%'",0,0,"'('","')'","'*'","'+'","','","'-'",0,"'/'",0,0,0,0,0,0,0,0,0,0, -"':'","';'","'<'",0,"'>'","'?'",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, -0,0,0,"'['",0,"']'","'^'",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,"'p'",0,0,0,0,0,0,0, -0,0,0,"'{'","'|'","'}'",0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, -0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,"BEGIN","END","REGEX","SEMINEW", -"NEWLINE","COMMENT","FUN1","FUNN","GRGR","PRINT","PRINTF","SPRINTF_OLD", -"SPRINTF_NEW","SPLIT","IF","ELSE","WHILE","FOR","IN","EXIT","NEXT","BREAK", -"CONTINUE","RET","GETLINE","DO","SUB","GSUB","MATCH","FUNCTION","USERFUN", -"DELETE","ASGNOP","OROR","ANDAND","NUMBER","VAR","SUBSTR","INDEX","MATCHOP", -"RELOP","OR","STRING","UMINUS","NOT","INCR","DECR","FIELD","VFIELD","SVFIELD", -}; -const char *yyrule[] = { -"$accept : program", -"program : junk hunks", -"begin : BEGIN '{' maybe states '}' junk", -"end : END '{' maybe states '}'", -"end : end NEWLINE", -"hunks : hunks hunk junk", -"hunks :", -"hunk : patpat", -"hunk : patpat '{' maybe states '}'", -"hunk : FUNCTION USERFUN '(' arg_list ')' maybe '{' maybe states '}'", -"hunk : '{' maybe states '}'", -"hunk : begin", -"hunk : end", -"arg_list : expr_list", -"patpat : cond", -"patpat : cond ',' cond", -"cond : expr", -"cond : match", -"cond : rel", -"cond : compound_cond", -"cond : cond '?' expr ':' expr", -"compound_cond : '(' compound_cond ')'", -"compound_cond : cond ANDAND maybe cond", -"compound_cond : cond OROR maybe cond", -"compound_cond : NOT cond", -"rel : expr RELOP expr", -"rel : expr '>' expr", -"rel : expr '<' expr", -"rel : '(' rel ')'", -"match : expr MATCHOP expr", -"match : expr MATCHOP REGEX", -"match : REGEX", -"match : '(' match ')'", -"expr : term", -"expr : expr term", -"expr : expr '?' expr ':' expr", -"expr : variable ASGNOP cond", -"sprintf : SPRINTF_NEW", -"sprintf : SPRINTF_OLD", -"term : variable", -"term : NUMBER", -"term : STRING", -"term : term '+' term", -"term : term '-' term", -"term : term '*' term", -"term : term '/' term", -"term : term '%' term", -"term : term '^' term", -"term : term IN VAR", -"term : variable INCR", -"term : variable DECR", -"term : INCR variable", -"term : DECR variable", -"term : '-' term", -"term : '+' term", -"term : '(' cond ')'", -"term : GETLINE", -"term : GETLINE variable", -"term : GETLINE '<' expr", -"term : GETLINE variable '<' expr", -"term : term 'p' GETLINE", -"term : term 'p' GETLINE variable", -"term : FUN1", -"term : FUN1 '(' ')'", -"term : FUN1 '(' expr ')'", -"term : FUNN '(' expr_list ')'", -"term : USERFUN '(' expr_list ')'", -"term : SPRINTF_NEW '(' expr_list ')'", -"term : sprintf expr_list", -"term : SUBSTR '(' expr ',' expr ',' expr ')'", -"term : SUBSTR '(' expr ',' expr ')'", -"term : SPLIT '(' expr ',' VAR ',' expr ')'", -"term : SPLIT '(' expr ',' VAR ',' REGEX ')'", -"term : SPLIT '(' expr ',' VAR ')'", -"term : INDEX '(' expr ',' expr ')'", -"term : MATCH '(' expr ',' REGEX ')'", -"term : MATCH '(' expr ',' expr ')'", -"term : SUB '(' expr ',' expr ')'", -"term : SUB '(' REGEX ',' expr ')'", -"term : GSUB '(' expr ',' expr ')'", -"term : GSUB '(' REGEX ',' expr ')'", -"term : SUB '(' expr ',' expr ',' expr ')'", -"term : SUB '(' REGEX ',' expr ',' expr ')'", -"term : GSUB '(' expr ',' expr ',' expr ')'", -"term : GSUB '(' REGEX ',' expr ',' expr ')'", -"variable : VAR", -"variable : VAR '[' expr_list ']'", -"variable : FIELD", -"variable : SVFIELD", -"variable : VFIELD term", -"expr_list : expr", -"expr_list : clist", -"expr_list :", -"clist : expr ',' maybe expr", -"clist : clist ',' maybe expr", -"clist : '(' clist ')'", -"junk : junk hunksep", -"junk :", -"hunksep : ';'", -"hunksep : SEMINEW", -"hunksep : NEWLINE", -"hunksep : COMMENT", -"maybe : maybe nlstuff", -"maybe :", -"nlstuff : NEWLINE", -"nlstuff : COMMENT", -"separator : ';' maybe", -"separator : SEMINEW maybe", -"separator : NEWLINE maybe", -"separator : COMMENT maybe", -"states : states statement", -"states :", -"statement : simple separator maybe", -"statement : ';' maybe", -"statement : SEMINEW maybe", -"statement : compound", -"simpnull : simple", -"simpnull :", -"simple : expr", -"simple : PRINT expr_list redir expr", -"simple : PRINT expr_list", -"simple : PRINTF expr_list redir expr", -"simple : PRINTF expr_list", -"simple : BREAK", -"simple : NEXT", -"simple : EXIT", -"simple : EXIT expr", -"simple : CONTINUE", -"simple : RET", -"simple : RET expr", -"simple : DELETE VAR '[' expr_list ']'", -"redir : '>'", -"redir : GRGR", -"redir : '|'", -"compound : IF '(' cond ')' maybe statement", -"compound : IF '(' cond ')' maybe statement ELSE maybe statement", -"compound : WHILE '(' cond ')' maybe statement", -"compound : DO maybe statement WHILE '(' cond ')'", -"compound : FOR '(' simpnull ';' cond ';' simpnull ')' maybe statement", -"compound : FOR '(' simpnull ';' ';' simpnull ')' maybe statement", -"compound : FOR '(' expr ')' maybe statement", -"compound : '{' maybe states '}' maybe", -}; -#endif -#ifndef YYSTYPE -typedef int YYSTYPE; -#endif -#ifdef YYSTACKSIZE -#undef YYMAXDEPTH -#define YYMAXDEPTH YYSTACKSIZE -#else -#ifdef YYMAXDEPTH -#define YYSTACKSIZE YYMAXDEPTH -#else -#define YYSTACKSIZE 500 -#define YYMAXDEPTH 500 -#endif -#endif -int yydebug; -int yynerrs; -int yyerrflag; -int yychar; -short *yyssp; -YYSTYPE *yyvsp; -YYSTYPE yyval; -YYSTYPE yylval; -short yyss[YYSTACKSIZE]; -YYSTYPE yyvs[YYSTACKSIZE]; -#define yystacksize YYSTACKSIZE -#line 429 "a2p.y" - -int yyparse (void); - -#include "a2py.c" -#line 2178 "y.tab.c" -#define YYABORT goto yyabort -#define YYREJECT goto yyabort -#define YYACCEPT goto yyaccept -#define YYERROR goto yyerrlab - -#if YYDEBUG -# if defined(WIN32) -EXTERN_C _CRTIMP char *getenv(const char *); -# else -EXTERN_C char *getenv(const char *); -# endif -#endif - -int -yyparse(void) -{ - int yym, yyn, yystate; -#if YYDEBUG - const char *yys; - - if ((yys = getenv("YYDEBUG"))) - { - yyn = *yys; - if (yyn >= '0' && yyn <= '9') - yydebug = yyn - '0'; - } -#endif - - yynerrs = 0; - yyerrflag = 0; - yychar = (-1); - - yyssp = yyss; - yyvsp = yyvs; - *yyssp = yystate = 0; - -yyloop: - if (((yyn = yydefred[yystate])) != 0) goto yyreduce; - if (yychar < 0) - { - if ((yychar = yylex()) < 0) yychar = 0; -#if YYDEBUG - if (yydebug) - { - yys = 0; - if (yychar <= YYMAXTOKEN) yys = yyname[yychar]; - if (!yys) yys = "illegal-symbol"; - printf("%sdebug: state %d, reading %d (%s)\n", - YYPREFIX, yystate, yychar, yys); - } -#endif - } - if ((yyn = yysindex[yystate]) && (yyn += yychar) >= 0 && - yyn <= YYTABLESIZE && yycheck[yyn] == yychar) - { -#if YYDEBUG - if (yydebug) - printf("%sdebug: state %d, shifting to state %d\n", - YYPREFIX, yystate, yytable[yyn]); -#endif - if (yyssp >= yyss + yystacksize - 1) - { - goto yyoverflow; - } - *++yyssp = yystate = yytable[yyn]; - *++yyvsp = yylval; - yychar = (-1); - if (yyerrflag > 0) --yyerrflag; - goto yyloop; - } - if ((yyn = yyrindex[yystate]) && (yyn += yychar) >= 0 && - yyn <= YYTABLESIZE && yycheck[yyn] == yychar) - { - yyn = yytable[yyn]; - goto yyreduce; - } - if (yyerrflag) goto yyinrecovery; -#ifdef lint - -#endif - - yyerror("syntax error"); -#ifdef lint - -#endif - - ++yynerrs; -yyinrecovery: - if (yyerrflag < 3) - { - yyerrflag = 3; - for (;;) - { - if ((yyn = yysindex[*yyssp]) && (yyn += YYERRCODE) >= 0 && - yyn <= YYTABLESIZE && yycheck[yyn] == YYERRCODE) - { -#if YYDEBUG - if (yydebug) - printf("%sdebug: state %d, error recovery shifting\ - to state %d\n", YYPREFIX, *yyssp, yytable[yyn]); -#endif - if (yyssp >= yyss + yystacksize - 1) - { - goto yyoverflow; - } - *++yyssp = yystate = yytable[yyn]; - *++yyvsp = yylval; - goto yyloop; - } - else - { -#if YYDEBUG - if (yydebug) - printf("%sdebug: error recovery discarding state %d\n", - YYPREFIX, *yyssp); -#endif - if (yyssp <= yyss) goto yyabort; - --yyssp; - --yyvsp; - } - } - } - else - { - if (yychar == 0) goto yyabort; -#if YYDEBUG - if (yydebug) - { - yys = 0; - if (yychar <= YYMAXTOKEN) yys = yyname[yychar]; - if (!yys) yys = "illegal-symbol"; - printf("%sdebug: state %d, error recovery discards token %d (%s)\n", - YYPREFIX, yystate, yychar, yys); - } -#endif - yychar = (-1); - goto yyloop; - } -yyreduce: -#if YYDEBUG - if (yydebug) - printf("%sdebug: state %d, reducing by rule %d (%s)\n", - YYPREFIX, yystate, yyn, yyrule[yyn]); -#endif - yym = yylen[yyn]; - yyval = yyvsp[1-yym]; - switch (yyn) - { -case 1: -#line 52 "a2p.y" -{ root = oper4(OPROG,yyvsp[-1],begins,yyvsp[0],ends); } -break; -case 2: -#line 56 "a2p.y" -{ begins = oper4(OJUNK,begins,yyvsp[-3],yyvsp[-2],yyvsp[0]); in_begin = FALSE; - yyval = Nullop; } -break; -case 3: -#line 61 "a2p.y" -{ ends = oper3(OJUNK,ends,yyvsp[-2],yyvsp[-1]); yyval = Nullop; } -break; -case 4: -#line 63 "a2p.y" -{ yyval = yyvsp[-1]; } -break; -case 5: -#line 67 "a2p.y" -{ yyval = oper3(OHUNKS,yyvsp[-2],yyvsp[-1],yyvsp[0]); } -break; -case 6: -#line 69 "a2p.y" -{ yyval = Nullop; } -break; -case 7: -#line 73 "a2p.y" -{ yyval = oper1(OHUNK,yyvsp[0]); need_entire = TRUE; } -break; -case 8: -#line 75 "a2p.y" -{ yyval = oper2(OHUNK,yyvsp[-4],oper2(OJUNK,yyvsp[-2],yyvsp[-1])); } -break; -case 9: -#line 77 "a2p.y" -{ fixfargs(yyvsp[-8],yyvsp[-6],0); yyval = oper5(OUSERDEF,yyvsp[-8],yyvsp[-6],yyvsp[-4],yyvsp[-2],yyvsp[-1]); } -break; -case 10: -#line 79 "a2p.y" -{ yyval = oper2(OHUNK,Nullop,oper2(OJUNK,yyvsp[-2],yyvsp[-1])); } -break; -case 13: -#line 85 "a2p.y" -{ yyval = rememberargs(yyval); } -break; -case 14: -#line 89 "a2p.y" -{ yyval = oper1(OPAT,yyvsp[0]); } -break; -case 15: -#line 91 "a2p.y" -{ yyval = oper2(ORANGE,yyvsp[-2],yyvsp[0]); } -break; -case 20: -#line 99 "a2p.y" -{ yyval = oper3(OCOND,yyvsp[-4],yyvsp[-2],yyvsp[0]); } -break; -case 21: -#line 104 "a2p.y" -{ yyval = oper1(OCPAREN,yyvsp[-1]); } -break; -case 22: -#line 106 "a2p.y" -{ yyval = oper3(OCANDAND,yyvsp[-3],yyvsp[-1],yyvsp[0]); } -break; -case 23: -#line 108 "a2p.y" -{ yyval = oper3(OCOROR,yyvsp[-3],yyvsp[-1],yyvsp[0]); } -break; -case 24: -#line 110 "a2p.y" -{ yyval = oper1(OCNOT,yyvsp[0]); } -break; -case 25: -#line 114 "a2p.y" -{ yyval = oper3(ORELOP,yyvsp[-1],yyvsp[-2],yyvsp[0]); } -break; -case 26: -#line 116 "a2p.y" -{ yyval = oper3(ORELOP,string(">",1),yyvsp[-2],yyvsp[0]); } -break; -case 27: -#line 118 "a2p.y" -{ yyval = oper3(ORELOP,string("<",1),yyvsp[-2],yyvsp[0]); } -break; -case 28: -#line 120 "a2p.y" -{ yyval = oper1(ORPAREN,yyvsp[-1]); } -break; -case 29: -#line 124 "a2p.y" -{ yyval = oper3(OMATCHOP,yyvsp[-1],yyvsp[-2],yyvsp[0]); } -break; -case 30: -#line 126 "a2p.y" -{ yyval = oper3(OMATCHOP,yyvsp[-1],yyvsp[-2],oper1(OREGEX,yyvsp[0])); } -break; -case 31: -#line 128 "a2p.y" -{ yyval = oper1(OREGEX,yyvsp[0]); } -break; -case 32: -#line 130 "a2p.y" -{ yyval = oper1(OMPAREN,yyvsp[-1]); } -break; -case 33: -#line 134 "a2p.y" -{ yyval = yyvsp[0]; } -break; -case 34: -#line 136 "a2p.y" -{ yyval = oper2(OCONCAT,yyvsp[-1],yyvsp[0]); } -break; -case 35: -#line 138 "a2p.y" -{ yyval = oper3(OCOND,yyvsp[-4],yyvsp[-2],yyvsp[0]); } -break; -case 36: -#line 140 "a2p.y" -{ - yyval = oper3(OASSIGN,yyvsp[-1],yyvsp[-2],yyvsp[0]); - if ((ops[yyvsp[-2]].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[yyvsp[-2]].ival & 255) == OVFLD) - lval_field = TRUE; - } -break; -case 39: -#line 153 "a2p.y" -{ yyval = yyvsp[0]; } -break; -case 40: -#line 155 "a2p.y" -{ yyval = oper1(ONUM,yyvsp[0]); } -break; -case 41: -#line 157 "a2p.y" -{ yyval = oper1(OSTR,yyvsp[0]); } -break; -case 42: -#line 159 "a2p.y" -{ yyval = oper2(OADD,yyvsp[-2],yyvsp[0]); } -break; -case 43: -#line 161 "a2p.y" -{ yyval = oper2(OSUBTRACT,yyvsp[-2],yyvsp[0]); } -break; -case 44: -#line 163 "a2p.y" -{ yyval = oper2(OMULT,yyvsp[-2],yyvsp[0]); } -break; -case 45: -#line 165 "a2p.y" -{ yyval = oper2(ODIV,yyvsp[-2],yyvsp[0]); } -break; -case 46: -#line 167 "a2p.y" -{ yyval = oper2(OMOD,yyvsp[-2],yyvsp[0]); } -break; -case 47: -#line 169 "a2p.y" -{ yyval = oper2(OPOW,yyvsp[-2],yyvsp[0]); } -break; -case 48: -#line 171 "a2p.y" -{ yyval = oper2(ODEFINED,aryrefarg(yyvsp[0]),yyvsp[-2]); } -break; -case 49: -#line 173 "a2p.y" -{ - yyval = oper1(OPOSTINCR,yyvsp[-1]); - if ((ops[yyvsp[-1]].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[yyvsp[-1]].ival & 255) == OVFLD) - lval_field = TRUE; - } -break; -case 50: -#line 181 "a2p.y" -{ - yyval = oper1(OPOSTDECR,yyvsp[-1]); - if ((ops[yyvsp[-1]].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[yyvsp[-1]].ival & 255) == OVFLD) - lval_field = TRUE; - } -break; -case 51: -#line 189 "a2p.y" -{ - yyval = oper1(OPREINCR,yyvsp[0]); - if ((ops[yyvsp[0]].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[yyvsp[0]].ival & 255) == OVFLD) - lval_field = TRUE; - } -break; -case 52: -#line 197 "a2p.y" -{ - yyval = oper1(OPREDECR,yyvsp[0]); - if ((ops[yyvsp[0]].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[yyvsp[0]].ival & 255) == OVFLD) - lval_field = TRUE; - } -break; -case 53: -#line 205 "a2p.y" -{ yyval = oper1(OUMINUS,yyvsp[0]); } -break; -case 54: -#line 207 "a2p.y" -{ yyval = oper1(OUPLUS,yyvsp[0]); } -break; -case 55: -#line 209 "a2p.y" -{ yyval = oper1(OPAREN,yyvsp[-1]); } -break; -case 56: -#line 211 "a2p.y" -{ yyval = oper0(OGETLINE); } -break; -case 57: -#line 213 "a2p.y" -{ yyval = oper1(OGETLINE,yyvsp[0]); } -break; -case 58: -#line 215 "a2p.y" -{ yyval = oper3(OGETLINE,Nullop,string("<",1),yyvsp[0]); - if (ops[yyvsp[0]].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } -break; -case 59: -#line 218 "a2p.y" -{ yyval = oper3(OGETLINE,yyvsp[-2],string("<",1),yyvsp[0]); - if (ops[yyvsp[0]].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } -break; -case 60: -#line 221 "a2p.y" -{ yyval = oper3(OGETLINE,Nullop,string("|",1),yyvsp[-2]); - if (ops[yyvsp[-2]].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } -break; -case 61: -#line 224 "a2p.y" -{ yyval = oper3(OGETLINE,yyvsp[0],string("|",1),yyvsp[-3]); - if (ops[yyvsp[-3]].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } -break; -case 62: -#line 227 "a2p.y" -{ yyval = oper0(yyvsp[0]); need_entire = do_chop = TRUE; } -break; -case 63: -#line 229 "a2p.y" -{ yyval = oper1(yyvsp[-2],Nullop); need_entire = do_chop = TRUE; } -break; -case 64: -#line 231 "a2p.y" -{ yyval = oper1(yyvsp[-3],yyvsp[-1]); } -break; -case 65: -#line 233 "a2p.y" -{ yyval = oper1(yyvsp[-3],yyvsp[-1]); } -break; -case 66: -#line 235 "a2p.y" -{ yyval = oper2(OUSERFUN,yyvsp[-3],yyvsp[-1]); } -break; -case 67: -#line 237 "a2p.y" -{ yyval = oper1(OSPRINTF,yyvsp[-1]); } -break; -case 68: -#line 239 "a2p.y" -{ yyval = oper1(OSPRINTF,yyvsp[0]); } -break; -case 69: -#line 241 "a2p.y" -{ yyval = oper3(OSUBSTR,yyvsp[-5],yyvsp[-3],yyvsp[-1]); } -break; -case 70: -#line 243 "a2p.y" -{ yyval = oper2(OSUBSTR,yyvsp[-3],yyvsp[-1]); } -break; -case 71: -#line 245 "a2p.y" -{ yyval = oper3(OSPLIT,yyvsp[-5],aryrefarg(numary(yyvsp[-3])),yyvsp[-1]); } -break; -case 72: -#line 247 "a2p.y" -{ yyval = oper3(OSPLIT,yyvsp[-5],aryrefarg(numary(yyvsp[-3])),oper1(OREGEX,yyvsp[-1]));} -break; -case 73: -#line 249 "a2p.y" -{ yyval = oper2(OSPLIT,yyvsp[-3],aryrefarg(numary(yyvsp[-1]))); } -break; -case 74: -#line 251 "a2p.y" -{ yyval = oper2(OINDEX,yyvsp[-3],yyvsp[-1]); } -break; -case 75: -#line 253 "a2p.y" -{ yyval = oper2(OMATCH,yyvsp[-3],oper1(OREGEX,yyvsp[-1])); } -break; -case 76: -#line 255 "a2p.y" -{ yyval = oper2(OMATCH,yyvsp[-3],yyvsp[-1]); } -break; -case 77: -#line 257 "a2p.y" -{ yyval = oper2(OSUB,yyvsp[-3],yyvsp[-1]); } -break; -case 78: -#line 259 "a2p.y" -{ yyval = oper2(OSUB,oper1(OREGEX,yyvsp[-3]),yyvsp[-1]); } -break; -case 79: -#line 261 "a2p.y" -{ yyval = oper2(OGSUB,yyvsp[-3],yyvsp[-1]); } -break; -case 80: -#line 263 "a2p.y" -{ yyval = oper2(OGSUB,oper1(OREGEX,yyvsp[-3]),yyvsp[-1]); } -break; -case 81: -#line 265 "a2p.y" -{ yyval = oper3(OSUB,yyvsp[-5],yyvsp[-3],yyvsp[-1]); } -break; -case 82: -#line 267 "a2p.y" -{ yyval = oper3(OSUB,oper1(OREGEX,yyvsp[-5]),yyvsp[-3],yyvsp[-1]); } -break; -case 83: -#line 269 "a2p.y" -{ yyval = oper3(OGSUB,yyvsp[-5],yyvsp[-3],yyvsp[-1]); } -break; -case 84: -#line 271 "a2p.y" -{ yyval = oper3(OGSUB,oper1(OREGEX,yyvsp[-5]),yyvsp[-3],yyvsp[-1]); } -break; -case 85: -#line 275 "a2p.y" -{ yyval = oper1(OVAR,yyvsp[0]); } -break; -case 86: -#line 277 "a2p.y" -{ yyval = oper2(OVAR,aryrefarg(yyvsp[-3]),yyvsp[-1]); } -break; -case 87: -#line 279 "a2p.y" -{ yyval = oper1(OFLD,yyvsp[0]); } -break; -case 88: -#line 281 "a2p.y" -{ yyval = oper1(OVFLD,oper1(OVAR,yyvsp[0])); } -break; -case 89: -#line 283 "a2p.y" -{ yyval = oper1(OVFLD,yyvsp[0]); } -break; -case 92: -#line 290 "a2p.y" -{ yyval = Nullop; } -break; -case 93: -#line 294 "a2p.y" -{ yyval = oper3(OCOMMA,yyvsp[-3],yyvsp[-1],yyvsp[0]); } -break; -case 94: -#line 296 "a2p.y" -{ yyval = oper3(OCOMMA,yyvsp[-3],yyvsp[-1],yyvsp[0]); } -break; -case 95: -#line 298 "a2p.y" -{ yyval = yyvsp[-1]; } -break; -case 96: -#line 302 "a2p.y" -{ yyval = oper2(OJUNK,yyvsp[-1],yyvsp[0]); } -break; -case 97: -#line 304 "a2p.y" -{ yyval = Nullop; } -break; -case 98: -#line 308 "a2p.y" -{ yyval = oper2(OJUNK,oper0(OSEMICOLON),oper0(ONEWLINE)); } -break; -case 99: -#line 310 "a2p.y" -{ yyval = oper2(OJUNK,oper0(OSEMICOLON),oper0(ONEWLINE)); } -break; -case 100: -#line 312 "a2p.y" -{ yyval = oper0(ONEWLINE); } -break; -case 101: -#line 314 "a2p.y" -{ yyval = oper1(OCOMMENT,yyvsp[0]); } -break; -case 102: -#line 318 "a2p.y" -{ yyval = oper2(OJUNK,yyvsp[-1],yyvsp[0]); } -break; -case 103: -#line 320 "a2p.y" -{ yyval = Nullop; } -break; -case 104: -#line 324 "a2p.y" -{ yyval = oper0(ONEWLINE); } -break; -case 105: -#line 326 "a2p.y" -{ yyval = oper1(OCOMMENT,yyvsp[0]); } -break; -case 106: -#line 331 "a2p.y" -{ yyval = oper2(OJUNK,oper0(OSEMICOLON),yyvsp[0]); } -break; -case 107: -#line 333 "a2p.y" -{ yyval = oper2(OJUNK,oper0(OSNEWLINE),yyvsp[0]); } -break; -case 108: -#line 335 "a2p.y" -{ yyval = oper2(OJUNK,oper0(OSNEWLINE),yyvsp[0]); } -break; -case 109: -#line 337 "a2p.y" -{ yyval = oper2(OJUNK,oper1(OSCOMMENT,yyvsp[-1]),yyvsp[0]); } -break; -case 110: -#line 341 "a2p.y" -{ yyval = oper2(OSTATES,yyvsp[-1],yyvsp[0]); } -break; -case 111: -#line 343 "a2p.y" -{ yyval = Nullop; } -break; -case 112: -#line 348 "a2p.y" -{ yyval = oper2(OJUNK,oper2(OSTATE,yyvsp[-2],yyvsp[-1]),yyvsp[0]); } -break; -case 113: -#line 350 "a2p.y" -{ yyval = oper2(OSTATE,Nullop,oper2(OJUNK,oper0(OSEMICOLON),yyvsp[0])); } -break; -case 114: -#line 352 "a2p.y" -{ yyval = oper2(OSTATE,Nullop,oper2(OJUNK,oper0(OSNEWLINE),yyvsp[0])); } -break; -case 117: -#line 358 "a2p.y" -{ yyval = Nullop; } -break; -case 119: -#line 364 "a2p.y" -{ yyval = oper3(OPRINT,yyvsp[-2],yyvsp[-1],yyvsp[0]); - do_opens = TRUE; - saw_ORS = saw_OFS = TRUE; - if (!yyvsp[-2]) need_entire = TRUE; - if (ops[yyvsp[0]].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } -break; -case 120: -#line 370 "a2p.y" -{ yyval = oper1(OPRINT,yyvsp[0]); - if (!yyvsp[0]) need_entire = TRUE; - saw_ORS = saw_OFS = TRUE; - } -break; -case 121: -#line 375 "a2p.y" -{ yyval = oper3(OPRINTF,yyvsp[-2],yyvsp[-1],yyvsp[0]); - do_opens = TRUE; - if (!yyvsp[-2]) need_entire = TRUE; - if (ops[yyvsp[0]].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } -break; -case 122: -#line 380 "a2p.y" -{ yyval = oper1(OPRINTF,yyvsp[0]); - if (!yyvsp[0]) need_entire = TRUE; - } -break; -case 123: -#line 384 "a2p.y" -{ yyval = oper0(OBREAK); } -break; -case 124: -#line 386 "a2p.y" -{ yyval = oper0(ONEXT); } -break; -case 125: -#line 388 "a2p.y" -{ yyval = oper0(OEXIT); } -break; -case 126: -#line 390 "a2p.y" -{ yyval = oper1(OEXIT,yyvsp[0]); } -break; -case 127: -#line 392 "a2p.y" -{ yyval = oper0(OCONTINUE); } -break; -case 128: -#line 394 "a2p.y" -{ yyval = oper0(ORETURN); } -break; -case 129: -#line 396 "a2p.y" -{ yyval = oper1(ORETURN,yyvsp[0]); } -break; -case 130: -#line 398 "a2p.y" -{ yyval = oper2(ODELETE,aryrefarg(yyvsp[-3]),yyvsp[-1]); } -break; -case 131: -#line 402 "a2p.y" -{ yyval = oper1(OREDIR,string(">",1)); } -break; -case 132: -#line 404 "a2p.y" -{ yyval = oper1(OREDIR,string(">>",2)); } -break; -case 133: -#line 406 "a2p.y" -{ yyval = oper1(OREDIR,string("|",1)); } -break; -case 134: -#line 411 "a2p.y" -{ yyval = oper2(OIF,yyvsp[-3],bl(yyvsp[0],yyvsp[-1])); } -break; -case 135: -#line 413 "a2p.y" -{ yyval = oper3(OIF,yyvsp[-6],bl(yyvsp[-3],yyvsp[-4]),bl(yyvsp[0],yyvsp[-1])); } -break; -case 136: -#line 415 "a2p.y" -{ yyval = oper2(OWHILE,yyvsp[-3],bl(yyvsp[0],yyvsp[-1])); } -break; -case 137: -#line 417 "a2p.y" -{ yyval = oper2(ODO,bl(yyvsp[-4],yyvsp[-5]),yyvsp[-1]); } -break; -case 138: -#line 419 "a2p.y" -{ yyval = oper4(OFOR,yyvsp[-7],yyvsp[-5],yyvsp[-3],bl(yyvsp[0],yyvsp[-1])); } -break; -case 139: -#line 421 "a2p.y" -{ yyval = oper4(OFOR,yyvsp[-6],string("",0),yyvsp[-3],bl(yyvsp[0],yyvsp[-1])); } -break; -case 140: -#line 423 "a2p.y" -{ yyval = oper2(OFORIN,yyvsp[-3],bl(yyvsp[0],yyvsp[-1])); } -break; -case 141: -#line 425 "a2p.y" -{ yyval = oper3(OBLOCK,oper2(OJUNK,yyvsp[-3],yyvsp[-2]),Nullop,yyvsp[0]); } -break; -#line 2878 "y.tab.c" - } - yyssp -= yym; - yystate = *yyssp; - yyvsp -= yym; - yym = yylhs[yyn]; - if (yystate == 0 && yym == 0) - { -#if YYDEBUG - if (yydebug) - printf("%sdebug: after reduction, shifting from state 0 to\ - state %d\n", YYPREFIX, YYFINAL); -#endif - yystate = YYFINAL; - *++yyssp = YYFINAL; - *++yyvsp = yyval; - if (yychar < 0) - { - if ((yychar = yylex()) < 0) yychar = 0; -#if YYDEBUG - if (yydebug) - { - yys = 0; - if (yychar <= YYMAXTOKEN) yys = yyname[yychar]; - if (!yys) yys = "illegal-symbol"; - printf("%sdebug: state %d, reading %d (%s)\n", - YYPREFIX, YYFINAL, yychar, yys); - } -#endif - } - if (yychar == 0) goto yyaccept; - goto yyloop; - } - if ((yyn = yygindex[yym]) && (yyn += yystate) >= 0 && - yyn <= YYTABLESIZE && yycheck[yyn] == yystate) - yystate = yytable[yyn]; - else - yystate = yydgoto[yym]; -#if YYDEBUG - if (yydebug) - printf("%sdebug: after reduction, shifting from state %d \ -to state %d\n", YYPREFIX, *yyssp, yystate); -#endif - if (yyssp >= yyss + yystacksize - 1) - { - goto yyoverflow; - } - *++yyssp = yystate; - *++yyvsp = yyval; - goto yyloop; -yyoverflow: - yyerror("yacc stack overflow"); -yyabort: - return (1); -yyaccept: - return (0); -} diff --git a/x2p/a2p.h b/x2p/a2p.h deleted file mode 100644 index 1d2a562744..0000000000 --- a/x2p/a2p.h +++ /dev/null @@ -1,462 +0,0 @@ -/* a2p.h - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, - * 2000, 2001, 2002, by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#ifdef WIN32 -#define _INC_WIN32_PERL5 /* kludge around win32 stdio layer */ -#endif - -#ifdef __VMS -# include "config.h" -#elif defined(NETWARE) -# include "../NetWare/config.h" -#else -# include "../config.h" -#endif - -#if defined(__STDC__) || defined(_AIX) || defined(__stdc__) || defined(__cplusplus) -# define STANDARD_C 1 -#endif - -#ifdef WIN32 -#undef USE_STDIO_PTR /* XXX fast gets won't work, must investigate */ -# ifndef STANDARD_C -# define STANDARD_C -# endif -#endif - -/* Use all the "standard" definitions? */ -#if defined(STANDARD_C) && defined(I_STDLIB) -# include <stdlib.h> -#endif /* STANDARD_C */ - -#include <stdio.h> - -#ifdef I_MATH -#include <math.h> -#endif - -#ifdef I_SYS_TYPES -# include <sys/types.h> -#endif - -#ifdef USE_NEXT_CTYPE - -#if NX_CURRENT_COMPILER_RELEASE >= 400 -#include <objc/NXCType.h> -#else /* NX_CURRENT_COMPILER_RELEASE < 400 */ -#include <appkit/NXCType.h> -#endif /* NX_CURRENT_COMPILER_RELEASE >= 400 */ - -#else /* !USE_NEXT_CTYPE */ -#include <ctype.h> -#endif /* USE_NEXT_CTYPE */ - -#define MEM_SIZE Size_t -#ifdef PERL_MEM_LOG - typedef IVTYPE IV; - typedef UVTYPE UV; -#endif - -#ifndef STANDARD_C - Malloc_t malloc (MEM_SIZE nbytes); - Malloc_t calloc (MEM_SIZE elements, MEM_SIZE size); - Malloc_t realloc (Malloc_t where, MEM_SIZE nbytes); - Free_t free (Malloc_t where); -#endif - -#if defined(I_STRING) || defined(__cplusplus) -# include <string.h> -#else -# include <strings.h> -#endif - -#if !defined(HAS_STRCHR) && defined(HAS_INDEX) && !defined(strchr) -#define strchr index -#define strrchr rindex -#endif - -#ifdef I_TIME -# include <time.h> -#endif - -#ifdef I_SYS_TIME -# ifdef I_SYS_TIME_KERNEL -# define KERNEL -# endif -# include <sys/time.h> -# ifdef I_SYS_TIME_KERNEL -# undef KERNEL -# endif -#endif - -#ifndef MSDOS -# if defined(HAS_TIMES) && defined(I_SYS_TIMES) -# include <sys/times.h> -# endif -#endif - -#ifdef DOSISH -# if defined(OS2) -# define PTHX_UNUSED -# include "../os2ish.h" -# else -# include "../dosish.h" -# endif -#else -# if defined(VMS) -# define NO_PERL_TYPEDEFS -# include "vmsish.h" -# endif -#endif - -#ifndef STANDARD_C -/* All of these are in stdlib.h or time.h for ANSI C */ -Time_t time(); -struct tm *gmtime(), *localtime(); -#if defined(OEMVS) -char *(strchr)(), *(strrchr)(); -char *(strcpy)(), *(strcat)(); -#else -char *strchr(), *strrchr(); -char *strcpy(), *strcat(); -#endif -#endif /* ! STANDARD_C */ - -#ifdef __cplusplus -# define PERL_EXPORT_C extern "C" -#else -# define PERL_EXPORT_C extern -#endif - -#ifdef VMS -# include "handy.h" -#else -# include "../handy.h" -#endif - -#define Nullop 0 - -#define OPROG 1 -#define OJUNK 2 -#define OHUNKS 3 -#define ORANGE 4 -#define OPAT 5 -#define OHUNK 6 -#define OPPAREN 7 -#define OPANDAND 8 -#define OPOROR 9 -#define OPNOT 10 -#define OCPAREN 11 -#define OCANDAND 12 -#define OCOROR 13 -#define OCNOT 14 -#define ORELOP 15 -#define ORPAREN 16 -#define OMATCHOP 17 -#define OMPAREN 18 -#define OCONCAT 19 -#define OASSIGN 20 -#define OADD 21 -#define OSUBTRACT 22 -#define OMULT 23 -#define ODIV 24 -#define OMOD 25 -#define OPOSTINCR 26 -#define OPOSTDECR 27 -#define OPREINCR 28 -#define OPREDECR 29 -#define OUMINUS 30 -#define OUPLUS 31 -#define OPAREN 32 -#define OGETLINE 33 -#define OSPRINTF 34 -#define OSUBSTR 35 -#define OSTRING 36 -#define OSPLIT 37 -#define OSNEWLINE 38 -#define OINDEX 39 -#define ONUM 40 -#define OSTR 41 -#define OVAR 42 -#define OFLD 43 -#define ONEWLINE 44 -#define OCOMMENT 45 -#define OCOMMA 46 -#define OSEMICOLON 47 -#define OSCOMMENT 48 -#define OSTATES 49 -#define OSTATE 50 -#define OPRINT 51 -#define OPRINTF 52 -#define OBREAK 53 -#define ONEXT 54 -#define OEXIT 55 -#define OCONTINUE 56 -#define OREDIR 57 -#define OIF 58 -#define OWHILE 59 -#define OFOR 60 -#define OFORIN 61 -#define OVFLD 62 -#define OBLOCK 63 -#define OREGEX 64 -#define OLENGTH 65 -#define OLOG 66 -#define OEXP 67 -#define OSQRT 68 -#define OINT 69 -#define ODO 70 -#define OPOW 71 -#define OSUB 72 -#define OGSUB 73 -#define OMATCH 74 -#define OUSERFUN 75 -#define OUSERDEF 76 -#define OCLOSE 77 -#define OATAN2 78 -#define OSIN 79 -#define OCOS 80 -#define ORAND 81 -#define OSRAND 82 -#define ODELETE 83 -#define OSYSTEM 84 -#define OCOND 85 -#define ORETURN 86 -#define ODEFINED 87 -#define OSTAR 88 - -#ifdef DOINIT -const char *opname[] = { - "0", - "PROG", - "JUNK", - "HUNKS", - "RANGE", - "PAT", - "HUNK", - "PPAREN", - "PANDAND", - "POROR", - "PNOT", - "CPAREN", - "CANDAND", - "COROR", - "CNOT", - "RELOP", - "RPAREN", - "MATCHOP", - "MPAREN", - "CONCAT", - "ASSIGN", - "ADD", - "SUBTRACT", - "MULT", - "DIV", - "MOD", - "POSTINCR", - "POSTDECR", - "PREINCR", - "PREDECR", - "UMINUS", - "UPLUS", - "PAREN", - "GETLINE", - "SPRINTF", - "SUBSTR", - "STRING", - "SPLIT", - "SNEWLINE", - "INDEX", - "NUM", - "STR", - "VAR", - "FLD", - "NEWLINE", - "COMMENT", - "COMMA", - "SEMICOLON", - "SCOMMENT", - "STATES", - "STATE", - "PRINT", - "PRINTF", - "BREAK", - "NEXT", - "EXIT", - "CONTINUE", - "REDIR", - "IF", - "WHILE", - "FOR", - "FORIN", - "VFLD", - "BLOCK", - "REGEX", - "LENGTH", - "LOG", - "EXP", - "SQRT", - "INT", - "DO", - "POW", - "SUB", - "GSUB", - "MATCH", - "USERFUN", - "USERDEF", - "CLOSE", - "ATAN2", - "SIN", - "COS", - "RAND", - "SRAND", - "DELETE", - "SYSTEM", - "COND", - "RETURN", - "DEFINED", - "STAR", - "89" -}; -#else -extern const char *opname[]; -#endif - -EXT int mop INIT(1); - -union u_ops { - int ival; - char *cval; -}; -#define OPSMAX 50000 -EXT union u_ops ops[OPSMAX]; - -typedef struct string STR; -typedef struct htbl HASH; - -#include "str.h" -#include "hash.h" - - -/* A string is TRUE if not "" or "0". */ -#define True(val) (tmps = (val), (*tmps && !(*tmps == '0' && !tmps[1]))) -EXT const char *Yes INIT("1"); -EXT const char *No INIT(""); - -#define str_get(str) (Str = (str), (Str->str_pok ? Str->str_ptr : str_2ptr(Str))) -EXT STR *Str; - -#define GROWSTR(pp,lp,len) if (*(lp) < (len)) growstr(pp,lp,len) - -/* Prototypes for things in a2p.c */ -int aryrefarg ( int arg ); -int bl ( int arg, int maybe ); -void dump ( int branch ); -int fixfargs ( int name, int arg, int prevargs ); -int fixrargs ( char *name, int arg, int prevargs ); -void fixup ( STR *str ); -int numary ( int arg ); -int oper0 ( int type ); -int oper1 ( int type, int arg1 ); -int oper2 ( int type, int arg1, int arg2 ); -int oper3 ( int type, int arg1, int arg2, int arg3 ); -int oper4 ( int type, int arg1, int arg2, int arg3, int arg4 ); -int oper5 ( int type, int arg1, int arg2, int arg3, int arg4, int arg5 ); -void putlines ( STR *str ); -void putone ( void ); -int rememberargs ( int arg ); -char * scannum ( char *s ); -char * scanpat ( char *s ); -int string ( const char *ptr, int len ); -void yyerror ( const char *s ); -int yylex ( void ); - -EXT int line INIT(0); - -EXT FILE *rsfp; -EXT char buf[2048]; -EXT char *bufptr INIT(buf); - -EXT STR *linestr INIT(NULL); - -EXT char tokenbuf[2048]; -EXT int expectterm INIT(TRUE); - -#ifdef DEBUGGING -EXT int debug INIT(0); -EXT int dlevel INIT(0); -#define YYDEBUG 1 -extern int yydebug; -#else -# ifndef YYDEBUG -# define YYDEBUG 0 -# endif -#endif - -EXT STR *freestrroot INIT(NULL); - -EXT STR str_no; -EXT STR str_yes; - -EXT bool do_split INIT(FALSE); -EXT bool split_to_array INIT(FALSE); -EXT bool saw_RS INIT(FALSE); -EXT bool saw_OFS INIT(FALSE); -EXT bool saw_ORS INIT(FALSE); -EXT bool saw_line_op INIT(FALSE); -EXT bool in_begin INIT(TRUE); -EXT bool do_opens INIT(FALSE); -EXT bool do_fancy_opens INIT(FALSE); -EXT bool lval_field INIT(FALSE); -EXT bool do_chop INIT(FALSE); -EXT bool need_entire INIT(FALSE); -EXT bool absmaxfld INIT(FALSE); -EXT bool saw_altinput INIT(FALSE); - -EXT bool nomemok INIT(FALSE); - -EXT char const_FS INIT(0); -EXT char *namelist INIT(NULL); -EXT char fswitch INIT(0); -EXT bool old_awk INIT(0); - -EXT int saw_FS INIT(0); -EXT int maxfld INIT(0); -EXT int arymax INIT(0); -EXT char *nameary[100]; - -EXT STR *opens; - -EXT HASH *symtab; -EXT HASH *curarghash; - -#define P_MIN 0 -#define P_LISTOP 5 -#define P_COMMA 10 -#define P_ASSIGN 15 -#define P_COND 20 -#define P_DOTDOT 25 -#define P_OROR 30 -#define P_ANDAND 35 -#define P_OR 40 -#define P_AND 45 -#define P_EQ 50 -#define P_REL 55 -#define P_UNI 60 -#define P_FILETEST 65 -#define P_SHIFT 70 -#define P_ADD 75 -#define P_MUL 80 -#define P_MATCH 85 -#define P_UNARY 90 -#define P_POW 95 -#define P_AUTO 100 -#define P_MAX 999 - -EXT int an; diff --git a/x2p/a2p.pod b/x2p/a2p.pod deleted file mode 100644 index aeddf9a0d5..0000000000 --- a/x2p/a2p.pod +++ /dev/null @@ -1,175 +0,0 @@ -=head1 NAME - -a2p - Awk to Perl translator - -=head1 SYNOPSIS - -B<a2p> [I<options>] [I<filename>] - -=head1 DESCRIPTION - -I<A2p> takes an awk script specified on the command line (or from -standard input) and produces a comparable I<perl> script on the -standard output. - -=head2 OPTIONS - -Options include: - -=over 5 - -=item B<-DE<lt>numberE<gt>> - -sets debugging flags. - -=item B<-FE<lt>characterE<gt>> - -tells a2p that this awk script is always invoked with this B<-F> -switch. - -=item B<-nE<lt>fieldlistE<gt>> - -specifies the names of the input fields if input does not have to be -split into an array. If you were translating an awk script that -processes the password file, you might say: - - a2p -7 -nlogin.password.uid.gid.gcos.shell.home - -Any delimiter can be used to separate the field names. - -=item B<-E<lt>numberE<gt>> - -causes a2p to assume that input will always have that many fields. - -=item B<-o> - -tells a2p to use old awk behavior. The only current differences are: - -=over 5 - -=item * - -Old awk always has a line loop, even if there are no line -actions, whereas new awk does not. - -=item * - -In old awk, sprintf is extremely greedy about its arguments. -For example, given the statement - - print sprintf(some_args), extra_args; - -old awk considers I<extra_args> to be arguments to C<sprintf>; new awk -considers them arguments to C<print>. - -=back - -=back - -=head2 "Considerations" - -A2p cannot do as good a job translating as a human would, but it -usually does pretty well. There are some areas where you may want to -examine the perl script produced and tweak it some. Here are some of -them, in no particular order. - -There is an awk idiom of putting int() around a string expression to -force numeric interpretation, even though the argument is always -integer anyway. This is generally unneeded in perl, but a2p can't -tell if the argument is always going to be integer, so it leaves it -in. You may wish to remove it. - -Perl differentiates numeric comparison from string comparison. Awk -has one operator for both that decides at run time which comparison to -do. A2p does not try to do a complete job of awk emulation at this -point. Instead it guesses which one you want. It's almost always -right, but it can be spoofed. All such guesses are marked with the -comment "C<#???>". You should go through and check them. You might -want to run at least once with the B<-w> switch to perl, which will -warn you if you use == where you should have used eq. - -Perl does not attempt to emulate the behavior of awk in which -nonexistent array elements spring into existence simply by being -referenced. If somehow you are relying on this mechanism to create -null entries for a subsequent for...in, they won't be there in perl. - -If a2p makes a split line that assigns to a list of variables that -looks like (Fld1, Fld2, Fld3...) you may want to rerun a2p using the -B<-n> option mentioned above. This will let you name the fields -throughout the script. If it splits to an array instead, the script -is probably referring to the number of fields somewhere. - -The exit statement in awk doesn't necessarily exit; it goes to the END -block if there is one. Awk scripts that do contortions within the END -block to bypass the block under such circumstances can be simplified -by removing the conditional in the END block and just exiting directly -from the perl script. - -Perl has two kinds of array, numerically-indexed and associative. -Perl associative arrays are called "hashes". Awk arrays are usually -translated to hashes, but if you happen to know that the index is -always going to be numeric you could change the {...} to [...]. -Iteration over a hash is done using the keys() function, but iteration -over an array is NOT. You might need to modify any loop that iterates -over such an array. - -Awk starts by assuming OFMT has the value %.6g. Perl starts by -assuming its equivalent, $#, to have the value %.20g. You'll want to -set $# explicitly if you use the default value of OFMT. - -Near the top of the line loop will be the split operation that is -implicit in the awk script. There are times when you can move this -down past some conditionals that test the entire record so that the -split is not done as often. - -For aesthetic reasons you may wish to change index variables from being -1-based (awk style) to 0-based (Perl style). Be sure to change all -operations the variable is involved in to match. - -Cute comments that say "# Here is a workaround because awk is dumb" -are passed through unmodified. - -Awk scripts are often embedded in a shell script that pipes stuff into -and out of awk. Often the shell script wrapper can be incorporated -into the perl script, since perl can start up pipes into and out of -itself, and can do other things that awk can't do by itself. - -Scripts that refer to the special variables RSTART and RLENGTH can -often be simplified by referring to the variables $`, $& and $', as -long as they are within the scope of the pattern match that sets them. - -The produced perl script may have subroutines defined to deal with -awk's semantics regarding getline and print. Since a2p usually picks -correctness over efficiency. it is almost always possible to rewrite -such code to be more efficient by discarding the semantic sugar. - -For efficiency, you may wish to remove the keyword from any return -statement that is the last statement executed in a subroutine. A2p -catches the most common case, but doesn't analyze embedded blocks for -subtler cases. - -ARGV[0] translates to $ARGV0, but ARGV[n] translates to $ARGV[$n-1]. A -loop that tries to iterate over ARGV[0] won't find it. - -=head1 ENVIRONMENT - -A2p uses no environment variables. - -=head1 AUTHOR - -Larry Wall E<lt>F<larry@wall.org>E<gt> - -=head1 SEE ALSO - - perl The perl compiler/interpreter - - s2p sed to perl translator - -=head1 BUGS - -It would be possible to emulate awk's behavior in selecting string -versus numeric operations at run time by inspection of the operands, -but it would be gross and inefficient. Besides, a2p almost always -guesses right. - -Storage for the awk syntax tree is currently static, and can run out. diff --git a/x2p/a2p.y b/x2p/a2p.y deleted file mode 100644 index 74c42d8c19..0000000000 --- a/x2p/a2p.y +++ /dev/null @@ -1,432 +0,0 @@ -%{ -/* $RCSfile: a2p.y,v $$Revision: 4.1 $$Date: 92/08/07 18:29:12 $ - * - * Copyright (C) 1991, 1992, 1993, 1994, 1996, 1997, 1999, 2000, - * by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - * - * $Log: a2p.y,v $ - */ - -#include "INTERN.h" -#include "a2p.h" - -int root; -int begins = Nullop; -int ends = Nullop; - -%} -%token BEGIN END -%token REGEX -%token SEMINEW NEWLINE COMMENT -%token FUN1 FUNN GRGR -%token PRINT PRINTF SPRINTF_OLD SPRINTF_NEW SPLIT -%token IF ELSE WHILE FOR IN -%token EXIT NEXT BREAK CONTINUE RET -%token GETLINE DO SUB GSUB MATCH -%token FUNCTION USERFUN DELETE - -%right ASGNOP -%right '?' ':' -%left OROR -%left ANDAND -%left IN -%left NUMBER VAR SUBSTR INDEX -%left MATCHOP -%left RELOP '<' '>' -%left OR -%left STRING -%left '+' '-' -%left '*' '/' '%' -%right UMINUS -%left NOT -%right '^' -%left INCR DECR -%left FIELD VFIELD SVFIELD - -%% - -program : junk hunks - { root = oper4(OPROG,$1,begins,$2,ends); } - ; - -begin : BEGIN '{' maybe states '}' junk - { begins = oper4(OJUNK,begins,$3,$4,$6); in_begin = FALSE; - $$ = Nullop; } - ; - -end : END '{' maybe states '}' - { ends = oper3(OJUNK,ends,$3,$4); $$ = Nullop; } - | end NEWLINE - { $$ = $1; } - ; - -hunks : hunks hunk junk - { $$ = oper3(OHUNKS,$1,$2,$3); } - | /* NULL */ - { $$ = Nullop; } - ; - -hunk : patpat - { $$ = oper1(OHUNK,$1); need_entire = TRUE; } - | patpat '{' maybe states '}' - { $$ = oper2(OHUNK,$1,oper2(OJUNK,$3,$4)); } - | FUNCTION USERFUN '(' arg_list ')' maybe '{' maybe states '}' - { fixfargs($2,$4,0); $$ = oper5(OUSERDEF,$2,$4,$6,$8,$9); } - | '{' maybe states '}' - { $$ = oper2(OHUNK,Nullop,oper2(OJUNK,$2,$3)); } - | begin - | end - ; - -arg_list: expr_list - { $$ = rememberargs($$); } - ; - -patpat : cond - { $$ = oper1(OPAT,$1); } - | cond ',' cond - { $$ = oper2(ORANGE,$1,$3); } - ; - -cond : expr - | match - | rel - | compound_cond - | cond '?' expr ':' expr - { $$ = oper3(OCOND,$1,$3,$5); } - ; - -compound_cond - : '(' compound_cond ')' - { $$ = oper1(OCPAREN,$2); } - | cond ANDAND maybe cond - { $$ = oper3(OCANDAND,$1,$3,$4); } - | cond OROR maybe cond - { $$ = oper3(OCOROR,$1,$3,$4); } - | NOT cond - { $$ = oper1(OCNOT,$2); } - ; - -rel : expr RELOP expr - { $$ = oper3(ORELOP,$2,$1,$3); } - | expr '>' expr - { $$ = oper3(ORELOP,string(">",1),$1,$3); } - | expr '<' expr - { $$ = oper3(ORELOP,string("<",1),$1,$3); } - | '(' rel ')' - { $$ = oper1(ORPAREN,$2); } - ; - -match : expr MATCHOP expr - { $$ = oper3(OMATCHOP,$2,$1,$3); } - | expr MATCHOP REGEX - { $$ = oper3(OMATCHOP,$2,$1,oper1(OREGEX,$3)); } - | REGEX %prec MATCHOP - { $$ = oper1(OREGEX,$1); } - | '(' match ')' - { $$ = oper1(OMPAREN,$2); } - ; - -expr : term - { $$ = $1; } - | expr term - { $$ = oper2(OCONCAT,$1,$2); } - | expr '?' expr ':' expr - { $$ = oper3(OCOND,$1,$3,$5); } - | variable ASGNOP cond - { - $$ = oper3(OASSIGN,$2,$1,$3); - if ((ops[$1].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[$1].ival & 255) == OVFLD) - lval_field = TRUE; - } - ; - -sprintf : SPRINTF_NEW - | SPRINTF_OLD ; - -term : variable - { $$ = $1; } - | NUMBER - { $$ = oper1(ONUM,$1); } - | STRING - { $$ = oper1(OSTR,$1); } - | term '+' term - { $$ = oper2(OADD,$1,$3); } - | term '-' term - { $$ = oper2(OSUBTRACT,$1,$3); } - | term '*' term - { $$ = oper2(OMULT,$1,$3); } - | term '/' term - { $$ = oper2(ODIV,$1,$3); } - | term '%' term - { $$ = oper2(OMOD,$1,$3); } - | term '^' term - { $$ = oper2(OPOW,$1,$3); } - | term IN VAR - { $$ = oper2(ODEFINED,aryrefarg($3),$1); } - | variable INCR - { - $$ = oper1(OPOSTINCR,$1); - if ((ops[$1].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[$1].ival & 255) == OVFLD) - lval_field = TRUE; - } - | variable DECR - { - $$ = oper1(OPOSTDECR,$1); - if ((ops[$1].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[$1].ival & 255) == OVFLD) - lval_field = TRUE; - } - | INCR variable - { - $$ = oper1(OPREINCR,$2); - if ((ops[$2].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[$2].ival & 255) == OVFLD) - lval_field = TRUE; - } - | DECR variable - { - $$ = oper1(OPREDECR,$2); - if ((ops[$2].ival & 255) == OFLD) - lval_field = TRUE; - else if ((ops[$2].ival & 255) == OVFLD) - lval_field = TRUE; - } - | '-' term %prec UMINUS - { $$ = oper1(OUMINUS,$2); } - | '+' term %prec UMINUS - { $$ = oper1(OUPLUS,$2); } - | '(' cond ')' - { $$ = oper1(OPAREN,$2); } - | GETLINE - { $$ = oper0(OGETLINE); } - | GETLINE variable - { $$ = oper1(OGETLINE,$2); } - | GETLINE '<' expr - { $$ = oper3(OGETLINE,Nullop,string("<",1),$3); - if (ops[$3].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } - | GETLINE variable '<' expr - { $$ = oper3(OGETLINE,$2,string("<",1),$4); - if (ops[$4].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } - | term 'p' GETLINE - { $$ = oper3(OGETLINE,Nullop,string("|",1),$1); - if (ops[$1].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } - | term 'p' GETLINE variable - { $$ = oper3(OGETLINE,$4,string("|",1),$1); - if (ops[$1].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } - | FUN1 - { $$ = oper0($1); need_entire = do_chop = TRUE; } - | FUN1 '(' ')' - { $$ = oper1($1,Nullop); need_entire = do_chop = TRUE; } - | FUN1 '(' expr ')' - { $$ = oper1($1,$3); } - | FUNN '(' expr_list ')' - { $$ = oper1($1,$3); } - | USERFUN '(' expr_list ')' - { $$ = oper2(OUSERFUN,$1,$3); } - | SPRINTF_NEW '(' expr_list ')' - { $$ = oper1(OSPRINTF,$3); } - | sprintf expr_list - { $$ = oper1(OSPRINTF,$2); } - | SUBSTR '(' expr ',' expr ',' expr ')' - { $$ = oper3(OSUBSTR,$3,$5,$7); } - | SUBSTR '(' expr ',' expr ')' - { $$ = oper2(OSUBSTR,$3,$5); } - | SPLIT '(' expr ',' VAR ',' expr ')' - { $$ = oper3(OSPLIT,$3,aryrefarg(numary($5)),$7); } - | SPLIT '(' expr ',' VAR ',' REGEX ')' - { $$ = oper3(OSPLIT,$3,aryrefarg(numary($5)),oper1(OREGEX,$7));} - | SPLIT '(' expr ',' VAR ')' - { $$ = oper2(OSPLIT,$3,aryrefarg(numary($5))); } - | INDEX '(' expr ',' expr ')' - { $$ = oper2(OINDEX,$3,$5); } - | MATCH '(' expr ',' REGEX ')' - { $$ = oper2(OMATCH,$3,oper1(OREGEX,$5)); } - | MATCH '(' expr ',' expr ')' - { $$ = oper2(OMATCH,$3,$5); } - | SUB '(' expr ',' expr ')' - { $$ = oper2(OSUB,$3,$5); } - | SUB '(' REGEX ',' expr ')' - { $$ = oper2(OSUB,oper1(OREGEX,$3),$5); } - | GSUB '(' expr ',' expr ')' - { $$ = oper2(OGSUB,$3,$5); } - | GSUB '(' REGEX ',' expr ')' - { $$ = oper2(OGSUB,oper1(OREGEX,$3),$5); } - | SUB '(' expr ',' expr ',' expr ')' - { $$ = oper3(OSUB,$3,$5,$7); } - | SUB '(' REGEX ',' expr ',' expr ')' - { $$ = oper3(OSUB,oper1(OREGEX,$3),$5,$7); } - | GSUB '(' expr ',' expr ',' expr ')' - { $$ = oper3(OGSUB,$3,$5,$7); } - | GSUB '(' REGEX ',' expr ',' expr ')' - { $$ = oper3(OGSUB,oper1(OREGEX,$3),$5,$7); } - ; - -variable: VAR - { $$ = oper1(OVAR,$1); } - | VAR '[' expr_list ']' - { $$ = oper2(OVAR,aryrefarg($1),$3); } - | FIELD - { $$ = oper1(OFLD,$1); } - | SVFIELD - { $$ = oper1(OVFLD,oper1(OVAR,$1)); } - | VFIELD term - { $$ = oper1(OVFLD,$2); } - ; - -expr_list - : expr - | clist - | /* NULL */ - { $$ = Nullop; } - ; - -clist : expr ',' maybe expr - { $$ = oper3(OCOMMA,$1,$3,$4); } - | clist ',' maybe expr - { $$ = oper3(OCOMMA,$1,$3,$4); } - | '(' clist ')' /* these parens are invisible */ - { $$ = $2; } - ; - -junk : junk hunksep - { $$ = oper2(OJUNK,$1,$2); } - | /* NULL */ - { $$ = Nullop; } - ; - -hunksep : ';' - { $$ = oper2(OJUNK,oper0(OSEMICOLON),oper0(ONEWLINE)); } - | SEMINEW - { $$ = oper2(OJUNK,oper0(OSEMICOLON),oper0(ONEWLINE)); } - | NEWLINE - { $$ = oper0(ONEWLINE); } - | COMMENT - { $$ = oper1(OCOMMENT,$1); } - ; - -maybe : maybe nlstuff - { $$ = oper2(OJUNK,$1,$2); } - | /* NULL */ - { $$ = Nullop; } - ; - -nlstuff : NEWLINE - { $$ = oper0(ONEWLINE); } - | COMMENT - { $$ = oper1(OCOMMENT,$1); } - ; - -separator - : ';' maybe - { $$ = oper2(OJUNK,oper0(OSEMICOLON),$2); } - | SEMINEW maybe - { $$ = oper2(OJUNK,oper0(OSNEWLINE),$2); } - | NEWLINE maybe - { $$ = oper2(OJUNK,oper0(OSNEWLINE),$2); } - | COMMENT maybe - { $$ = oper2(OJUNK,oper1(OSCOMMENT,$1),$2); } - ; - -states : states statement - { $$ = oper2(OSTATES,$1,$2); } - | /* NULL */ - { $$ = Nullop; } - ; - -statement - : simple separator maybe - { $$ = oper2(OJUNK,oper2(OSTATE,$1,$2),$3); } - | ';' maybe - { $$ = oper2(OSTATE,Nullop,oper2(OJUNK,oper0(OSEMICOLON),$2)); } - | SEMINEW maybe - { $$ = oper2(OSTATE,Nullop,oper2(OJUNK,oper0(OSNEWLINE),$2)); } - | compound - ; - -simpnull: simple - | /* NULL */ - { $$ = Nullop; } - ; - -simple - : expr - | PRINT expr_list redir expr - { $$ = oper3(OPRINT,$2,$3,$4); - do_opens = TRUE; - saw_ORS = saw_OFS = TRUE; - if (!$2) need_entire = TRUE; - if (ops[$4].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } - | PRINT expr_list - { $$ = oper1(OPRINT,$2); - if (!$2) need_entire = TRUE; - saw_ORS = saw_OFS = TRUE; - } - | PRINTF expr_list redir expr - { $$ = oper3(OPRINTF,$2,$3,$4); - do_opens = TRUE; - if (!$2) need_entire = TRUE; - if (ops[$4].ival != OSTR + (1<<8)) do_fancy_opens = TRUE; } - | PRINTF expr_list - { $$ = oper1(OPRINTF,$2); - if (!$2) need_entire = TRUE; - } - | BREAK - { $$ = oper0(OBREAK); } - | NEXT - { $$ = oper0(ONEXT); } - | EXIT - { $$ = oper0(OEXIT); } - | EXIT expr - { $$ = oper1(OEXIT,$2); } - | CONTINUE - { $$ = oper0(OCONTINUE); } - | RET - { $$ = oper0(ORETURN); } - | RET expr - { $$ = oper1(ORETURN,$2); } - | DELETE VAR '[' expr_list ']' - { $$ = oper2(ODELETE,aryrefarg($2),$4); } - ; - -redir : '>' %prec FIELD - { $$ = oper1(OREDIR,string(">",1)); } - | GRGR - { $$ = oper1(OREDIR,string(">>",2)); } - | '|' - { $$ = oper1(OREDIR,string("|",1)); } - ; - -compound - : IF '(' cond ')' maybe statement - { $$ = oper2(OIF,$3,bl($6,$5)); } - | IF '(' cond ')' maybe statement ELSE maybe statement - { $$ = oper3(OIF,$3,bl($6,$5),bl($9,$8)); } - | WHILE '(' cond ')' maybe statement - { $$ = oper2(OWHILE,$3,bl($6,$5)); } - | DO maybe statement WHILE '(' cond ')' - { $$ = oper2(ODO,bl($3,$2),$6); } - | FOR '(' simpnull ';' cond ';' simpnull ')' maybe statement - { $$ = oper4(OFOR,$3,$5,$7,bl($10,$9)); } - | FOR '(' simpnull ';' ';' simpnull ')' maybe statement - { $$ = oper4(OFOR,$3,string("",0),$6,bl($9,$8)); } - | FOR '(' expr ')' maybe statement - { $$ = oper2(OFORIN,$3,bl($6,$5)); } - | '{' maybe states '}' maybe - { $$ = oper3(OBLOCK,oper2(OJUNK,$2,$3),Nullop,$5); } - ; - -%% - -int yyparse (void); - -#include "a2py.c" diff --git a/x2p/a2py.c b/x2p/a2py.c deleted file mode 100644 index 695c4fd56e..0000000000 --- a/x2p/a2py.c +++ /dev/null @@ -1,1300 +0,0 @@ -/* a2py.c - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, - * 2000, 2001, 2002, by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#if defined(OS2) || defined(WIN32) || defined(NETWARE) -#if defined(WIN32) -#include <io.h> -#endif -#if defined(NETWARE) -#include "../netware/clibstuf.h" -#endif -#include "../patchlevel.h" -#endif -#include "util.h" -#include "../unicode_constants.h" -#define DELETE_CHAR DEL_NATIVE - -const char *filename; -const char *myname; - -int checkers = 0; - -int oper0(int type); -int oper1(int type, int arg1); -int oper2(int type, int arg1, int arg2); -int oper3(int type, int arg1, int arg2, int arg3); -int oper4(int type, int arg1, int arg2, int arg3, int arg4); -int oper5(int type, int arg1, int arg2, int arg3, int arg4, int arg5); -STR *walk(int useval, int level, int node, int *numericptr, int minprec); -#ifdef NETWARE -char *savestr(char *str); -char *cpy2(char *to, char *from, int delim); -#endif - -#if defined(OS2) || defined(WIN32) || defined(NETWARE) -static void usage(void); - -static void -usage() -{ - printf("\nThis is the AWK to PERL translator, revision %d.0, version %d\n", PERL_REVISION, PERL_VERSION); - printf("\nUsage: %s [-D<number>] [-F<char>] [-n<fieldlist>] [-<number>] filename\n", myname); - printf("\n -D<number> sets debugging flags." - "\n -F<character> the awk script to translate is always invoked with" - "\n this -F switch." - "\n -n<fieldlist> specifies the names of the input fields if input does" - "\n not have to be split into an array." - "\n -<number> causes a2p to assume that input will always have that" - "\n many fields.\n"); - exit(1); -} -#endif - -int -main(int argc, const char **argv) -{ - STR *str; - int i; - STR *tmpstr; - /* char *namelist; */ - - #ifdef NETWARE - fnInitGpfGlobals(); /* For importing the CLIB calls in place of Watcom calls */ - #endif /* NETWARE */ - - myname = argv[0]; - linestr = str_new(80); - for (argc--,argv++; argc; argc--,argv++) { - if (argv[0][0] != '-' || !argv[0][1]) - break; - switch (argv[0][1]) { -#ifdef DEBUGGING - case 'D': - debug = atoi(argv[0]+2); -#if YYDEBUG - yydebug = (debug & 1); -#endif - break; -#endif - case '0': case '1': case '2': case '3': case '4': - case '5': case '6': case '7': case '8': case '9': - maxfld = atoi(argv[0]+1); - absmaxfld = TRUE; - break; - case 'F': - fswitch = argv[0][2]; - break; - case 'n': - namelist = savestr(argv[0]+2); - break; - case 'o': - old_awk = TRUE; - break; - case '-': - argc--,argv++; - goto switch_end; - case 0: - break; - default: -#if defined(OS2) || defined(WIN32) || defined(NETWARE) - fprintf(stderr, "Unrecognized switch: %s\n",argv[0]); - usage(); -#else - fatal("Unrecognized switch: %s\n",argv[0]); -#endif - } - } - switch_end: - - /* open script */ - - if (argv[0] == NULL) { -#if defined(OS2) || defined(WIN32) || defined(NETWARE) - if ( isatty(fileno(stdin)) ) - usage(); -#endif - argv[0] = "-"; - } - filename = savestr(argv[0]); - - if (strEQ(filename,"-")) - argv[0] = ""; - if (!*argv[0]) - rsfp = stdin; - else - rsfp = fopen(argv[0],"r"); - if (rsfp == NULL) - fatal("Awk script \"%s\" doesn't seem to exist.\n",filename); - - /* init tokener */ - - bufptr = str_get(linestr); - symtab = hnew(); - curarghash = hnew(); - - /* now parse the report spec */ - - if (yyparse()) - fatal("Translation aborted due to syntax errors.\n"); - -#ifdef DEBUGGING - if (debug & 2) { - int type, len; - - for (i=1; i<mop;) { - type = ops[i].ival; - len = type >> 8; - type &= 255; - printf("%d\t%d\t%d\t%-10s",i++,type,len,opname[type]); - if (type == OSTRING) - printf("\t\"%s\"\n",ops[i].cval),i++; - else { - while (len--) { - printf("\t%d",ops[i].ival),i++; - } - putchar('\n'); - } - } - } - if (debug & 8) - dump(root); -#endif - - /* first pass to look for numeric variables */ - - prewalk(0,0,root,&i); - - /* second pass to produce new program */ - - tmpstr = walk(0,0,root,&i,P_MIN); - str = str_make(STARTPERL); - str_cat(str, "\neval 'exec "); - str_cat(str, BIN); - str_cat(str, "/perl -S $0 ${1+\"$@\"}'\n\ - if $running_under_some_shell;\n\ - # this emulates #! processing on NIH machines.\n\ - # (remove #! line above if indigestible)\n\n"); - str_cat(str, - "eval '$'.$1.'$2;' while $ARGV[0] =~ /^([A-Za-z_0-9]+=)(.*)/ && shift;\n"); - str_cat(str, - " # process any FOO=bar switches\n\n"); - if (do_opens && opens) { - str_scat(str,opens); - str_free(opens); - str_cat(str,"\n"); - } - str_scat(str,tmpstr); - str_free(tmpstr); -#ifdef DEBUGGING - if (!(debug & 16)) -#endif - fixup(str); - putlines(str); - if (checkers) { - fprintf(stderr, - "Please check my work on the %d line%s I've marked with \"#???\".\n", - checkers, checkers == 1 ? "" : "s" ); - fprintf(stderr, - "The operation I've selected may be wrong for the operand types.\n"); - } - exit(0); - /* by ANSI specs return is needed. This also shuts up VC++ and his warnings */ - return(0); -} - -#define RETURN(retval) return (bufptr = s,retval) -#define XTERM(retval) return (expectterm = TRUE,bufptr = s,retval) -#define XOP(retval) return (expectterm = FALSE,bufptr = s,retval) -#define ID(x) return (yylval=string(x,0),expectterm = FALSE,bufptr = s,idtype) - -int idtype; - -int -yylex(void) -{ - char *s = bufptr; - char *d; - int tmp; - - retry: -#if YYDEBUG - if (yydebug) { - if (strchr(s,'\n')) - fprintf(stderr,"Tokener at %s",s); - else - fprintf(stderr,"Tokener at %s\n",s); - } -#endif - switch (*s) { - default: - fprintf(stderr, - "Unrecognized character %c in file %s line %d--ignoring.\n", - *s++,filename,line); - goto retry; - case '\\': - s++; - if (*s && *s != '\n') { - yyerror("Ignoring spurious backslash"); - goto retry; - } - /*FALLSTHROUGH*/ - case 0: - s = str_get(linestr); - *s = '\0'; - if (!rsfp) - RETURN(0); - line++; - if ((s = str_gets(linestr, rsfp)) == NULL) { - if (rsfp != stdin) - fclose(rsfp); - rsfp = NULL; - s = str_get(linestr); - RETURN(0); - } - goto retry; - case ' ': case '\t': - s++; - goto retry; - case '\n': - *s = '\0'; - XTERM(NEWLINE); - case '#': - yylval = string(s,0); - *s = '\0'; - XTERM(COMMENT); - case ';': - tmp = *s++; - if (*s == '\n') { - s++; - XTERM(SEMINEW); - } - XTERM(tmp); - case '(': - tmp = *s++; - XTERM(tmp); - case '{': - case '[': - case ')': - case ']': - case '?': - case ':': - tmp = *s++; - XOP(tmp); - case DELETE_CHAR: - s++; - XTERM('}'); - case '}': - for (d = s + 1; isSPACE(*d); d++) ; - if (!*d) - s = d - 1; - *s = 127; - XTERM(';'); - case ',': - tmp = *s++; - XTERM(tmp); - case '~': - s++; - yylval = string("~",1); - XTERM(MATCHOP); - case '+': - case '-': - if (s[1] == *s) { - s++; - if (*s++ == '+') - XTERM(INCR); - else - XTERM(DECR); - } - /* FALL THROUGH */ - case '*': - case '%': - case '^': - tmp = *s++; - if (*s == '=') { - if (tmp == '^') - yylval = string("**=",3); - else - yylval = string(s-1,2); - s++; - XTERM(ASGNOP); - } - XTERM(tmp); - case '&': - s++; - tmp = *s++; - if (tmp == '&') - XTERM(ANDAND); - s--; - XTERM('&'); - case '|': - s++; - tmp = *s++; - if (tmp == '|') - XTERM(OROR); - s--; - while (*s == ' ' || *s == '\t') - s++; - if (strnEQ(s,"getline",7)) - XTERM('p'); - else - XTERM('|'); - case '=': - s++; - tmp = *s++; - if (tmp == '=') { - yylval = string("==",2); - XTERM(RELOP); - } - s--; - yylval = string("=",1); - XTERM(ASGNOP); - case '!': - s++; - tmp = *s++; - if (tmp == '=') { - yylval = string("!=",2); - XTERM(RELOP); - } - if (tmp == '~') { - yylval = string("!~",2); - XTERM(MATCHOP); - } - s--; - XTERM(NOT); - case '<': - s++; - tmp = *s++; - if (tmp == '=') { - yylval = string("<=",2); - XTERM(RELOP); - } - s--; - XTERM('<'); - case '>': - s++; - tmp = *s++; - if (tmp == '>') { - yylval = string(">>",2); - XTERM(GRGR); - } - if (tmp == '=') { - yylval = string(">=",2); - XTERM(RELOP); - } - s--; - XTERM('>'); - -#define SNARFWORD \ - d = tokenbuf; \ - while (isWORDCHAR(*s)) \ - *d++ = *s++; \ - *d = '\0'; \ - d = tokenbuf; \ - if (*s == '(') \ - idtype = USERFUN; \ - else \ - idtype = VAR; - - case '$': - s++; - if (*s == '0') { - s++; - do_chop = TRUE; - need_entire = TRUE; - idtype = VAR; - ID("0"); - } - do_split = TRUE; - if (isDIGIT(*s)) { - for (d = s; isDIGIT(*s); s++) ; - yylval = string(d,s-d); - tmp = atoi(d); - if (tmp > maxfld) - maxfld = tmp; - XOP(FIELD); - } - for (d = s; isWORDCHAR(*s); ) - s++; - split_to_array = TRUE; - if (d != s) - { - yylval = string(d,s-d); - XTERM(SVFIELD); - } - XOP(VFIELD); - - case '/': /* may either be division or pattern */ - if (expectterm) { - s = scanpat(s); - XTERM(REGEX); - } - tmp = *s++; - if (*s == '=') { - yylval = string("/=",2); - s++; - XTERM(ASGNOP); - } - XTERM(tmp); - - case '0': case '1': case '2': case '3': case '4': - case '5': case '6': case '7': case '8': case '9': case '.': - s = scannum(s); - XOP(NUMBER); - case '"': - s++; - s = cpy2(tokenbuf,s,s[-1]); - if (!*s) - fatal("String not terminated:\n%s",str_get(linestr)); - s++; - yylval = string(tokenbuf,0); - XOP(STRING); - - case 'a': case 'A': - SNARFWORD; - if (strEQ(d,"ARGV")) { - yylval=numary(string("ARGV",0)); - XOP(VAR); - } - if (strEQ(d,"atan2")) { - yylval = OATAN2; - XTERM(FUNN); - } - ID(d); - case 'b': case 'B': - SNARFWORD; - if (strEQ(d,"break")) - XTERM(BREAK); - if (strEQ(d,"BEGIN")) - XTERM(BEGIN); - ID(d); - case 'c': case 'C': - SNARFWORD; - if (strEQ(d,"continue")) - XTERM(CONTINUE); - if (strEQ(d,"cos")) { - yylval = OCOS; - XTERM(FUN1); - } - if (strEQ(d,"close")) { - do_fancy_opens = 1; - yylval = OCLOSE; - XTERM(FUN1); - } - if (strEQ(d,"chdir")) - *d = toUPPER(*d); - else if (strEQ(d,"crypt")) - *d = toUPPER(*d); - else if (strEQ(d,"chop")) - *d = toUPPER(*d); - else if (strEQ(d,"chmod")) - *d = toUPPER(*d); - else if (strEQ(d,"chown")) - *d = toUPPER(*d); - ID(d); - case 'd': case 'D': - SNARFWORD; - if (strEQ(d,"do")) - XTERM(DO); - if (strEQ(d,"delete")) - XTERM(DELETE); - if (strEQ(d,"die")) - *d = toUPPER(*d); - ID(d); - case 'e': case 'E': - SNARFWORD; - if (strEQ(d,"END")) - XTERM(END); - if (strEQ(d,"else")) - XTERM(ELSE); - if (strEQ(d,"exit")) { - saw_line_op = TRUE; - XTERM(EXIT); - } - if (strEQ(d,"exp")) { - yylval = OEXP; - XTERM(FUN1); - } - if (strEQ(d,"elsif")) - *d = toUPPER(*d); - else if (strEQ(d,"eq")) - *d = toUPPER(*d); - else if (strEQ(d,"eval")) - *d = toUPPER(*d); - else if (strEQ(d,"eof")) - *d = toUPPER(*d); - else if (strEQ(d,"each")) - *d = toUPPER(*d); - else if (strEQ(d,"exec")) - *d = toUPPER(*d); - ID(d); - case 'f': case 'F': - SNARFWORD; - if (strEQ(d,"FS")) { - saw_FS++; - if (saw_FS == 1 && in_begin) { - for (d = s; *d && isSPACE(*d); d++) ; - if (*d == '=') { - for (d++; *d && isSPACE(*d); d++) ; - if (*d == '"' && d[2] == '"') - const_FS = d[1]; - } - } - ID(tokenbuf); - } - if (strEQ(d,"for")) - XTERM(FOR); - else if (strEQ(d,"function")) - XTERM(FUNCTION); - if (strEQ(d,"FILENAME")) - ID("ARGV"); - if (strEQ(d,"foreach")) - *d = toUPPER(*d); - else if (strEQ(d,"format")) - *d = toUPPER(*d); - else if (strEQ(d,"fork")) - *d = toUPPER(*d); - else if (strEQ(d,"fh")) - *d = toUPPER(*d); - ID(d); - case 'g': case 'G': - SNARFWORD; - if (strEQ(d,"getline")) - XTERM(GETLINE); - if (strEQ(d,"gsub")) - XTERM(GSUB); - if (strEQ(d,"ge")) - *d = toUPPER(*d); - else if (strEQ(d,"gt")) - *d = toUPPER(*d); - else if (strEQ(d,"goto")) - *d = toUPPER(*d); - else if (strEQ(d,"gmtime")) - *d = toUPPER(*d); - ID(d); - case 'h': case 'H': - SNARFWORD; - if (strEQ(d,"hex")) - *d = toUPPER(*d); - ID(d); - case 'i': case 'I': - SNARFWORD; - if (strEQ(d,"if")) - XTERM(IF); - if (strEQ(d,"in")) - XTERM(IN); - if (strEQ(d,"index")) { - XTERM(INDEX); - } - if (strEQ(d,"int")) { - yylval = OINT; - XTERM(FUN1); - } - ID(d); - case 'j': case 'J': - SNARFWORD; - if (strEQ(d,"join")) - *d = toUPPER(*d); - ID(d); - case 'k': case 'K': - SNARFWORD; - if (strEQ(d,"keys")) - *d = toUPPER(*d); - else if (strEQ(d,"kill")) - *d = toUPPER(*d); - ID(d); - case 'l': case 'L': - SNARFWORD; - if (strEQ(d,"length")) { - yylval = OLENGTH; - XTERM(FUN1); - } - if (strEQ(d,"log")) { - yylval = OLOG; - XTERM(FUN1); - } - if (strEQ(d,"last")) - *d = toUPPER(*d); - else if (strEQ(d,"local")) - *d = toUPPER(*d); - else if (strEQ(d,"lt")) - *d = toUPPER(*d); - else if (strEQ(d,"le")) - *d = toUPPER(*d); - else if (strEQ(d,"locatime")) - *d = toUPPER(*d); - else if (strEQ(d,"link")) - *d = toUPPER(*d); - ID(d); - case 'm': case 'M': - SNARFWORD; - if (strEQ(d,"match")) { - XTERM(MATCH); - } - if (strEQ(d,"m")) - *d = toUPPER(*d); - ID(d); - case 'n': case 'N': - SNARFWORD; - if (strEQ(d,"NF")) - do_chop = do_split = split_to_array = TRUE; - if (strEQ(d,"next")) { - saw_line_op = TRUE; - XTERM(NEXT); - } - if (strEQ(d,"ne")) - *d = toUPPER(*d); - ID(d); - case 'o': case 'O': - SNARFWORD; - if (strEQ(d,"ORS")) { - saw_ORS = TRUE; - ID("\\"); - } - if (strEQ(d,"OFS")) { - saw_OFS = TRUE; - ID(","); - } - if (strEQ(d,"OFMT")) { - ID("#"); - } - if (strEQ(d,"open")) - *d = toUPPER(*d); - else if (strEQ(d,"ord")) - *d = toUPPER(*d); - else if (strEQ(d,"oct")) - *d = toUPPER(*d); - ID(d); - case 'p': case 'P': - SNARFWORD; - if (strEQ(d,"print")) { - XTERM(PRINT); - } - if (strEQ(d,"printf")) { - XTERM(PRINTF); - } - if (strEQ(d,"push")) - *d = toUPPER(*d); - else if (strEQ(d,"pop")) - *d = toUPPER(*d); - ID(d); - case 'q': case 'Q': - SNARFWORD; - ID(d); - case 'r': case 'R': - SNARFWORD; - if (strEQ(d,"RS")) { - saw_RS = TRUE; - ID("/"); - } - if (strEQ(d,"rand")) { - yylval = ORAND; - XTERM(FUN1); - } - if (strEQ(d,"return")) - XTERM(RET); - if (strEQ(d,"reset")) - *d = toUPPER(*d); - else if (strEQ(d,"redo")) - *d = toUPPER(*d); - else if (strEQ(d,"rename")) - *d = toUPPER(*d); - ID(d); - case 's': case 'S': - SNARFWORD; - if (strEQ(d,"split")) { - XOP(SPLIT); - } - if (strEQ(d,"substr")) { - XTERM(SUBSTR); - } - if (strEQ(d,"sub")) - XTERM(SUB); - if (strEQ(d,"sprintf")) { - /* In old awk, { print sprintf("str%sg"),"in" } prints - * "string"; in new awk, "in" is not considered an argument to - * sprintf, so the statement breaks. To support both, the - * grammar treats arguments to SPRINTF_OLD like old awk, - * SPRINTF_NEW like new. Here we return the appropriate one. - */ - XTERM(old_awk ? SPRINTF_OLD : SPRINTF_NEW); - } - if (strEQ(d,"sqrt")) { - yylval = OSQRT; - XTERM(FUN1); - } - if (strEQ(d,"SUBSEP")) { - ID(";"); - } - if (strEQ(d,"sin")) { - yylval = OSIN; - XTERM(FUN1); - } - if (strEQ(d,"srand")) { - yylval = OSRAND; - XTERM(FUN1); - } - if (strEQ(d,"system")) { - yylval = OSYSTEM; - XTERM(FUN1); - } - if (strEQ(d,"s")) - *d = toUPPER(*d); - else if (strEQ(d,"shift")) - *d = toUPPER(*d); - else if (strEQ(d,"select")) - *d = toUPPER(*d); - else if (strEQ(d,"seek")) - *d = toUPPER(*d); - else if (strEQ(d,"stat")) - *d = toUPPER(*d); - else if (strEQ(d,"study")) - *d = toUPPER(*d); - else if (strEQ(d,"sleep")) - *d = toUPPER(*d); - else if (strEQ(d,"symlink")) - *d = toUPPER(*d); - else if (strEQ(d,"sort")) - *d = toUPPER(*d); - ID(d); - case 't': case 'T': - SNARFWORD; - if (strEQ(d,"tr")) - *d = toUPPER(*d); - else if (strEQ(d,"tell")) - *d = toUPPER(*d); - else if (strEQ(d,"time")) - *d = toUPPER(*d); - else if (strEQ(d,"times")) - *d = toUPPER(*d); - ID(d); - case 'u': case 'U': - SNARFWORD; - if (strEQ(d,"until")) - *d = toUPPER(*d); - else if (strEQ(d,"unless")) - *d = toUPPER(*d); - else if (strEQ(d,"umask")) - *d = toUPPER(*d); - else if (strEQ(d,"unshift")) - *d = toUPPER(*d); - else if (strEQ(d,"unlink")) - *d = toUPPER(*d); - else if (strEQ(d,"utime")) - *d = toUPPER(*d); - ID(d); - case 'v': case 'V': - SNARFWORD; - if (strEQ(d,"values")) - *d = toUPPER(*d); - ID(d); - case 'w': case 'W': - SNARFWORD; - if (strEQ(d,"while")) - XTERM(WHILE); - if (strEQ(d,"write")) - *d = toUPPER(*d); - else if (strEQ(d,"wait")) - *d = toUPPER(*d); - ID(d); - case 'x': case 'X': - SNARFWORD; - if (strEQ(d,"x")) - *d = toUPPER(*d); - ID(d); - case 'y': case 'Y': - SNARFWORD; - if (strEQ(d,"y")) - *d = toUPPER(*d); - ID(d); - case 'z': case 'Z': - SNARFWORD; - ID(d); - } -} - -char * -scanpat(char *s) -{ - char *d; - - switch (*s++) { - case '/': - break; - default: - fatal("Search pattern not found:\n%s",str_get(linestr)); - } - - d = tokenbuf; - for (; *s; s++,d++) { - if (*s == '\\') { - if (s[1] == '/') - *d++ = *s++; - else if (s[1] == '\\') - *d++ = *s++; - else if (s[1] == '[') - *d++ = *s++; - } - else if (*s == '[') { - *d++ = *s++; - do { - if (*s == '\\' && s[1]) - *d++ = *s++; - if (*s == '/' || (*s == '-' && s[1] == ']')) - *d++ = '\\'; - *d++ = *s++; - } while (*s && *s != ']'); - } - else if (*s == '/') - break; - *d = *s; - } - *d = '\0'; - - if (!*s) - fatal("Search pattern not terminated:\n%s",str_get(linestr)); - s++; - yylval = string(tokenbuf,0); - return s; -} - -void -yyerror(const char *s) -{ - fprintf(stderr,"%s in file %s at line %d\n", - s,filename,line); -} - -char * -scannum(char *s) -{ - char *d; - - switch (*s) { - case '1': case '2': case '3': case '4': case '5': - case '6': case '7': case '8': case '9': case '0' : case '.': - d = tokenbuf; - while (isDIGIT(*s)) { - *d++ = *s++; - } - if (*s == '.') { - if (isDIGIT(s[1])) { - *d++ = *s++; - while (isDIGIT(*s)) { - *d++ = *s++; - } - } - else - s++; - } - if (strchr("eE",*s) && strchr("+-0123456789",s[1])) { - *d++ = *s++; - if (*s == '+' || *s == '-') - *d++ = *s++; - while (isDIGIT(*s)) - *d++ = *s++; - } - *d = '\0'; - yylval = string(tokenbuf,0); - break; - } - return s; -} - -int -string(const char *ptr, int len) -{ - int retval = mop; - - ops[mop++].ival = OSTRING + (1<<8); - if (!len) - len = strlen(ptr); - ops[mop].cval = (char *) safemalloc(len+1); - strncpy(ops[mop].cval,ptr,len); - ops[mop++].cval[len] = '\0'; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int -oper0(int type) -{ - int retval = mop; - - if (type > 255) - fatal("type > 255 (%d)\n",type); - ops[mop++].ival = type; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int -oper1(int type, int arg1) -{ - int retval = mop; - - if (type > 255) - fatal("type > 255 (%d)\n",type); - ops[mop++].ival = type + (1<<8); - ops[mop++].ival = arg1; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int -oper2(int type, int arg1, int arg2) -{ - int retval = mop; - - if (type > 255) - fatal("type > 255 (%d)\n",type); - ops[mop++].ival = type + (2<<8); - ops[mop++].ival = arg1; - ops[mop++].ival = arg2; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int -oper3(int type, int arg1, int arg2, int arg3) -{ - int retval = mop; - - if (type > 255) - fatal("type > 255 (%d)\n",type); - ops[mop++].ival = type + (3<<8); - ops[mop++].ival = arg1; - ops[mop++].ival = arg2; - ops[mop++].ival = arg3; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int -oper4(int type, int arg1, int arg2, int arg3, int arg4) -{ - int retval = mop; - - if (type > 255) - fatal("type > 255 (%d)\n",type); - ops[mop++].ival = type + (4<<8); - ops[mop++].ival = arg1; - ops[mop++].ival = arg2; - ops[mop++].ival = arg3; - ops[mop++].ival = arg4; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int -oper5(int type, int arg1, int arg2, int arg3, int arg4, int arg5) -{ - int retval = mop; - - if (type > 255) - fatal("type > 255 (%d)\n",type); - ops[mop++].ival = type + (5<<8); - ops[mop++].ival = arg1; - ops[mop++].ival = arg2; - ops[mop++].ival = arg3; - ops[mop++].ival = arg4; - ops[mop++].ival = arg5; - if (mop >= OPSMAX) - fatal("Recompile a2p with larger OPSMAX\n"); - return retval; -} - -int depth = 0; - -void -dump(int branch) -{ - int type; - int len; - int i; - - type = ops[branch].ival; - len = type >> 8; - type &= 255; - for (i=depth; i; i--) - printf(" "); - if (type == OSTRING) { - printf("%-5d\"%s\"\n",branch,ops[branch+1].cval); - } - else { - printf("(%-5d%s %d\n",branch,opname[type],len); - depth++; - for (i=1; i<=len; i++) - dump(ops[branch+i].ival); - depth--; - for (i=depth; i; i--) - printf(" "); - printf(")\n"); - } -} - -int -bl(int arg, int maybe) -{ - if (!arg) - return 0; - else if ((ops[arg].ival & 255) != OBLOCK) - return oper2(OBLOCK,arg,maybe); - else if ((ops[arg].ival >> 8) < 2) - return oper2(OBLOCK,ops[arg+1].ival,maybe); - else - return arg; -} - -void -fixup(STR *str) -{ - char *s; - char *t; - - for (s = str->str_ptr; *s; s++) { - if (*s == ';' && s[1] == ' ' && s[2] == '\n') { - strcpy(s+1,s+2); - s++; - } - else if (*s == '\n') { - for (t = s+1; isSPACE(*t & 127); t++) ; - t--; - while (isSPACE(*t & 127) && *t != '\n') t--; - if (*t == '\n' && t-s > 1) { - if (s[-1] == '{') - s--; - strcpy(s+1,t); - } - s++; - } - } -} - -void -putlines(STR *str) -{ - char *d, *s, *t, *e; - int pos, newpos; - - d = tokenbuf; - pos = 0; - for (s = str->str_ptr; *s; s++) { - *d++ = *s; - pos++; - if (*s == '\n') { - *d = '\0'; - d = tokenbuf; - pos = 0; - putone(); - } - else if (*s == '\t') - pos += 7; - if (pos > 78) { /* split a long line? */ - *d-- = '\0'; - newpos = 0; - for (t = tokenbuf; isSPACE(*t & 127); t++) { - if (*t == '\t') - newpos += 8; - else - newpos += 1; - } - e = d; - while (d > tokenbuf && (*d != ' ' || d[-1] != ';')) - d--; - if (d < t+10) { - d = e; - while (d > tokenbuf && - (*d != ' ' || d[-1] != '|' || d[-2] != '|') ) - d--; - } - if (d < t+10) { - d = e; - while (d > tokenbuf && - (*d != ' ' || d[-1] != '&' || d[-2] != '&') ) - d--; - } - if (d < t+10) { - d = e; - while (d > tokenbuf && (*d != ' ' || d[-1] != ',')) - d--; - } - if (d < t+10) { - d = e; - while (d > tokenbuf && *d != ' ') - d--; - } - if (d > t+3) { - char save[2048]; - strcpy(save, d); - *d = '\n'; - d[1] = '\0'; - putone(); - putchar('\n'); - if (d[-1] != ';' && !(newpos % 4)) { - *t++ = ' '; - *t++ = ' '; - newpos += 2; - } - strcpy(t,save+1); - newpos += strlen(t); - d = t + strlen(t); - pos = newpos; - } - else - d = e + 1; - } - } -} - -void -putone(void) -{ - char *t; - - for (t = tokenbuf; *t; t++) { - *t &= 127; - if (*t == 127) { - *t = ' '; - strcpy(t+strlen(t)-1, "\t#???\n"); - checkers++; - } - } - t = tokenbuf; - if (*t == '#') { - if (strnEQ(t,"#!/bin/awk",10) || strnEQ(t,"#! /bin/awk",11)) - return; - if (strnEQ(t,"#!/usr/bin/awk",14) || strnEQ(t,"#! /usr/bin/awk",15)) - return; - } - fputs(tokenbuf,stdout); -} - -int -numary(int arg) -{ - STR *key; - int dummy; - - key = walk(0,0,arg,&dummy,P_MIN); - str_cat(key,"[]"); - hstore(symtab,key->str_ptr,str_make("1")); - str_free(key); - return arg; -} - -int -rememberargs(int arg) -{ - int type; - STR *str; - - if (!arg) - return arg; - type = ops[arg].ival & 255; - if (type == OCOMMA) { - rememberargs(ops[arg+1].ival); - rememberargs(ops[arg+3].ival); - } - else if (type == OVAR) { - str = str_new(0); - hstore(curarghash,ops[ops[arg+1].ival+1].cval,str); - } - else - fatal("panic: unknown argument type %d, line %d\n",type,line); - return arg; -} - -int -aryrefarg(int arg) -{ - int type = ops[arg].ival & 255; - STR *str; - - if (type != OSTRING) - fatal("panic: aryrefarg %d, line %d\n",type,line); - str = hfetch(curarghash,ops[arg+1].cval); - if (str) - str_set(str,"*"); - return arg; -} - -int -fixfargs(int name, int arg, int prevargs) -{ - int type; - STR *str; - int numargs = 0; - - if (!arg) - return prevargs; - type = ops[arg].ival & 255; - if (type == OCOMMA) { - numargs = fixfargs(name,ops[arg+1].ival,prevargs); - numargs = fixfargs(name,ops[arg+3].ival,numargs); - } - else if (type == OVAR) { - str = hfetch(curarghash,ops[ops[arg+1].ival+1].cval); - if (strEQ(str_get(str),"*")) { - char tmpbuf[128]; - - str_set(str,""); /* in case another routine has this */ - ops[arg].ival &= ~255; - ops[arg].ival |= OSTAR; - sprintf(tmpbuf,"%s:%d",ops[name+1].cval,prevargs); - fprintf(stderr,"Adding %s\n",tmpbuf); - str = str_new(0); - str_set(str,"*"); - hstore(curarghash,tmpbuf,str); - } - numargs = prevargs + 1; - } - else - fatal("panic: unknown argument type %d, arg %d, line %d\n", - type,prevargs+1,line); - return numargs; -} - -int -fixrargs(char *name, int arg, int prevargs) -{ - int type; - STR *str; - int numargs; - - if (!arg) - return prevargs; - type = ops[arg].ival & 255; - if (type == OCOMMA) { - numargs = fixrargs(name,ops[arg+1].ival,prevargs); - numargs = fixrargs(name,ops[arg+3].ival,numargs); - } - else { - char *tmpbuf = (char *) safemalloc(strlen(name) + (sizeof(prevargs) * 3) + 5); - sprintf(tmpbuf,"%s:%d",name,prevargs); - str = hfetch(curarghash,tmpbuf); - safefree(tmpbuf); - if (str && strEQ(str->str_ptr,"*")) { - if (type == OVAR || type == OSTAR) { - ops[arg].ival &= ~255; - ops[arg].ival |= OSTAR; - } - else - fatal("Can't pass expression by reference as arg %d of %s\n", - prevargs+1, name); - } - numargs = prevargs + 1; - } - return numargs; -} diff --git a/x2p/find2perl.PL b/x2p/find2perl.PL deleted file mode 100644 index d68c0362e8..0000000000 --- a/x2p/find2perl.PL +++ /dev/null @@ -1,919 +0,0 @@ -#!/usr/local/bin/perl - -use Config; -use File::Basename qw(&basename &dirname); -use Cwd; - -# List explicitly here the variables you want Configure to -# generate. Metaconfig only looks for shell variables, so you -# have to mention them as if they were shell variables, not -# %Config entries. Thus you write -# $startperl -# to ensure Configure will look for $Config{startperl}. - -# This forces PL files to create target in same directory as PL file. -# This is so that make depend always knows where to find PL derivatives. -$origdir = cwd; -chdir dirname($0); -$file = basename($0, '.PL'); -$file .= '.com' if $^O eq 'VMS'; - -open OUT,">$file" or die "Can't create $file: $!"; - -print "Extracting $file (with variable substitutions)\n"; - -# In this section, perl variables will be expanded during extraction. -# You can use $Config{...} to use Configure variables. - -print OUT <<"!GROK!THIS!"; -$Config{startperl} - eval 'exec $Config{perlpath} -S \$0 \${1+"\$@"}' - if \$running_under_some_shell; -(my \$perlpath = <<'/../') =~ s/\\s*\\z//; -$Config{perlpath} -/../ -!GROK!THIS! - -# In the following, perl variables are not expanded during extraction. - -print OUT <<'!NO!SUBS!'; -use strict; -use vars qw/$statdone/; -use File::Spec::Functions 'curdir'; -my $startperl = "#! $perlpath -w"; - -sub tab (); -sub n ($$); -sub fileglob_to_re ($); -sub quote ($); - -my @roots = (); -while ($ARGV[0] =~ /^[^-!(]/) { - push(@roots, shift); -} -@roots = (curdir()) unless @roots; -for (@roots) { $_ = quote($_) } -my $roots = join(', ', @roots); - -my $find = "find"; -my $indent_depth = 1; -my $stat = 'lstat'; -my $decl = ''; -my $flushall = ''; -my $initfile = ''; -my $initnewer = ''; -my $out = ''; -my $declaresubs = "sub wanted;\n"; -my %init = (); -my ($follow_in_effect,$Skip_And) = (0,0); -my $print_needed = 1; - -while (@ARGV) { - $_ = shift; - s/^-// || /^[()!]/ || die "Unrecognized switch: $_\n"; - if ($_ eq '(') { - $out .= tab . "(\n"; - $indent_depth++; - next; - } elsif ($_ eq ')') { - --$indent_depth; - $out .= tab . ")"; - } elsif ($_ eq 'follow') { - $follow_in_effect= 1; - $stat = 'stat'; - $Skip_And= 1; - } elsif ($_ eq '!') { - $out .= tab . "!"; - next; - } elsif (/^(i)?name$/) { - $out .= tab . '/' . fileglob_to_re(shift) . "/s$1"; - } elsif (/^(i)?path$/) { - $out .= tab . '$File::Find::name =~ /' . fileglob_to_re(shift) . "/s$1"; - } elsif ($_ eq 'perm') { - my $onum = shift; - $onum =~ /^-?[0-7]+$/ - || die "Malformed -perm argument: $onum\n"; - $out .= tab; - if ($onum =~ s/^-//) { - $onum = sprintf("0%o", oct($onum) & 07777); - $out .= "((\$mode & $onum) == $onum)"; - } else { - $onum =~ s/^0*/0/; - $out .= "((\$mode & 0777) == $onum)"; - } - } elsif ($_ eq 'type') { - (my $filetest = shift) =~ tr/s/S/; - $out .= tab . "-$filetest _"; - } elsif ($_ eq 'print') { - $out .= tab . 'print("$name\n")'; - $print_needed = 0; - } elsif ($_ eq 'print0') { - $out .= tab . 'print("$name\0")'; - $print_needed = 0; - } elsif ($_ eq 'fstype') { - my $type = shift; - $out .= tab; - if ($type eq 'nfs') { - $out .= '($dev < 0)'; - } else { - $out .= '($dev >= 0)'; #XXX - } - } elsif ($_ eq 'user') { - my $uname = shift; - $out .= tab . "(\$uid == \$uid{'$uname'})"; - $init{user} = 1; - } elsif ($_ eq 'group') { - my $gname = shift; - $out .= tab . "(\$gid == \$gid{'$gname'})"; - $init{group} = 1; - } elsif ($_ eq 'nouser') { - $out .= tab . '!exists $uid{$uid}'; - $init{user} = 1; - } elsif ($_ eq 'nogroup') { - $out .= tab . '!exists $gid{$gid}'; - $init{group} = 1; - } elsif ($_ eq 'links') { - $out .= tab . n('$nlink', shift); - } elsif ($_ eq 'inum') { - $out .= tab . n('$ino', shift); - } elsif ($_ eq 'size') { - $_ = shift; - my $n = 'int(((-s _) + 511) / 512)'; - if (s/c\z//) { - $n = 'int(-s _)'; - } elsif (s/k\z//) { - $n = 'int(((-s _) + 1023) / 1024)'; - } - $out .= tab . n($n, $_); - } elsif ($_ eq 'atime') { - $out .= tab . n('int(-A _)', shift); - } elsif ($_ eq 'mtime') { - $out .= tab . n('int(-M _)', shift); - } elsif ($_ eq 'ctime') { - $out .= tab . n('int(-C _)', shift); - } elsif ($_ eq 'exec') { - my @cmd = (); - while (@ARGV && $ARGV[0] ne ';') - { push(@cmd, shift) } - shift; - $out .= tab; - if ($cmd[0] =~m#^(?:(?:/usr)?/bin/)?rm$# - && $cmd[$#cmd] eq '{}' - && (@cmd == 2 || (@cmd == 3 && $cmd[1] eq '-f'))) { - if (@cmd == 2) { - $out .= '(unlink($_) || warn "$name: $!\n")'; - } elsif (!@ARGV) { - $out .= 'unlink($_)'; - } else { - $out .= '(unlink($_) || 1)'; - } - } else { - for (@cmd) - { s/'/\\'/g } - { local $" = "','"; $out .= "doexec(0, '@cmd')"; } - $declaresubs .= "sub doexec (\$\@);\n"; - $init{doexec} = 1; - } - $print_needed = 0; - } elsif ($_ eq 'ok') { - my @cmd = (); - while (@ARGV && $ARGV[0] ne ';') - { push(@cmd, shift) } - shift; - $out .= tab; - for (@cmd) - { s/'/\\'/g } - { local $" = "','"; $out .= "doexec(1, '@cmd')"; } - $declaresubs .= "sub doexec (\$\@);\n"; - $init{doexec} = 1; - $print_needed = 0; - } elsif ($_ eq 'prune') { - $out .= tab . '($File::Find::prune = 1)'; - } elsif ($_ eq 'xdev') { - $out .= tab . '!($File::Find::prune |= ($dev != $File::Find::topdev))' -; - } elsif ($_ eq 'newer') { - my $file = shift; - my $newername = 'AGE_OF' . $file; - $newername =~ s/\W/_/g; - $newername = '$' . $newername; - $out .= tab . "(-M _ < $newername)"; - $initnewer .= "my $newername = -M " . quote($file) . ";\n"; - } elsif ($_ eq 'eval') { - my $prog = shift; - $prog =~ s/'/\\'/g; - $out .= tab . "eval {$prog}"; - $print_needed = 0; - } elsif ($_ eq 'depth') { - $find = 'finddepth'; - next; - } elsif ($_ eq 'ls') { - $out .= tab . "ls"; - $declaresubs .= "sub ls ();\n"; - $init{ls} = 1; - $print_needed = 0; - } elsif ($_ eq 'tar') { - die "-tar must have a filename argument\n" unless @ARGV; - my $file = shift; - my $fh = 'FH' . $file; - $fh =~ s/\W/_/g; - $out .= tab . "tar(*$fh, \$name)"; - $flushall .= "tflushall;\n"; - $declaresubs .= "sub tar;\nsub tflushall ();\n"; - $initfile .= "open($fh, " . quote('> ' . $file) . - qq{) || die "Can't open $fh: \$!\\n";\n}; - $init{tar} = 1; - } elsif (/^(n?)cpio\z/) { - die "-$_ must have a filename argument\n" unless @ARGV; - my $file = shift; - my $fh = 'FH' . $file; - $fh =~ s/\W/_/g; - $out .= tab . "cpio(*$fh, \$name, '$1')"; - $find = 'finddepth'; - $flushall .= "cflushall;\n"; - $declaresubs .= "sub cpio;\nsub cflushall ();\n"; - $initfile .= "open($fh, " . quote('> ' . $file) . - qq{) || die "Can't open $fh: \$!\\n";\n}; - $init{cpio} = 1; - } else { - die "Unrecognized switch: -$_\n"; - } - - if (@ARGV) { - if ($ARGV[0] eq '-o') { - { local($statdone) = 1; $out .= "\n" . tab . "||\n"; } - $statdone = 0 if $indent_depth == 1 && exists $init{delayedstat}; - $init{saw_or} = 1; - shift; - } else { - $out .= " &&" unless $Skip_And || $ARGV[0] eq ')'; - $out .= "\n"; - shift if $ARGV[0] eq '-a'; - } - } -} - -if ($print_needed) { - my $t = tab; - if ($t !~ /&&\s*$/) { $t .= '&& ' } - $out .= "\n" . $t . 'print("$name\n")'; -} - - -print <<"END"; -$startperl - eval 'exec $perlpath -S \$0 \${1+"\$@"}' - if 0; #\$running_under_some_shell - -use strict; -use File::Find (); - -# Set the variable \$File::Find::dont_use_nlink if you're using AFS, -# since AFS cheats. - -# for the convenience of &wanted calls, including -eval statements: -use vars qw/*name *dir *prune/; -*name = *File::Find::name; -*dir = *File::Find::dir; -*prune = *File::Find::prune; - -$declaresubs - -END - -if (exists $init{doexec}) { - print <<'END'; -use Cwd (); -my $cwd = Cwd::cwd(); - -END -} - -if (exists $init{ls}) { - print <<'END'; -my @rwx = qw(--- --x -w- -wx r-- r-x rw- rwx); -my @moname = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec); - -END -} - -if (exists $init{user} || exists $init{ls} || exists $init{tar}) { - print "my (%uid, %user);\n"; - print "while (my (\$name, \$pw, \$uid) = getpwent) {\n"; - print ' $uid{$name} = $uid{$uid} = $uid;', "\n" - if exists $init{user}; - print ' $user{$uid} = $name unless exists $user{$uid};', "\n" - if exists $init{ls} || exists $init{tar}; - print "}\n\n"; -} - -if (exists $init{group} || exists $init{ls} || exists $init{tar}) { - print "my (%gid, %group);\n"; - print "while (my (\$name, \$pw, \$gid) = getgrent) {\n"; - print ' $gid{$name} = $gid{$gid} = $gid;', "\n" - if exists $init{group}; - print ' $group{$gid} = $name unless exists $group{$gid};', "\n" - if exists $init{ls} || exists $init{tar}; - print "}\n\n"; -} - -print $initnewer, "\n" if $initnewer ne ''; -print $initfile, "\n" if $initfile ne ''; -$flushall .= "exit;\n"; -if (exists $init{declarestat}) { - $out = <<'END' . $out; - my ($dev,$ino,$mode,$nlink,$uid,$gid); - -END -} - -if ( $follow_in_effect ) { -$out =~ s/lstat\(\$_\)/lstat(_)/; -print <<"END"; -$decl -# Traverse desired filesystems -File::Find::$find( {wanted => \\&wanted, follow => 1}, $roots); -$flushall - -sub wanted { -$out; -} - -END -} else { -print <<"END"; -$decl -# Traverse desired filesystems -File::Find::$find({wanted => \\&wanted}, $roots); -$flushall - -sub wanted { -$out; -} - -END -} - -if (exists $init{doexec}) { - print <<'END'; - -sub doexec ($@) { - my $ok = shift; - my @command = @_; # copy so we don't try to s/// aliases to constants - for my $word (@command) - { $word =~ s#{}#$name#g } - if ($ok) { - my $old = select(STDOUT); - $| = 1; - print "@command"; - select($old); - return 0 unless <STDIN> =~ /^y/; - } - chdir $cwd; #sigh - system @command; - chdir $File::Find::dir; - return !$?; -} - -END -} - -if (exists $init{ls}) { - print <<'INTRO', <<"SUB", <<'END'; - -sub sizemm { - my $rdev = shift; - sprintf("%3d, %3d", ($rdev >> 8) & 0xff, $rdev & 0xff); -} - -sub ls () { - my ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size, -INTRO - \$atime,\$mtime,\$ctime,\$blksize,\$blocks) = $stat(_); -SUB - my $pname = $name; - - $blocks - or $blocks = int(($size + 1023) / 1024); - - my $perms = $rwx[$mode & 7]; - $mode >>= 3; - $perms = $rwx[$mode & 7] . $perms; - $mode >>= 3; - $perms = $rwx[$mode & 7] . $perms; - substr($perms, 2, 1) =~ tr/-x/Ss/ if -u _; - substr($perms, 5, 1) =~ tr/-x/Ss/ if -g _; - substr($perms, 8, 1) =~ tr/-x/Tt/ if -k _; - if (-f _) { $perms = '-' . $perms; } - elsif (-d _) { $perms = 'd' . $perms; } - elsif (-l _) { $perms = 'l' . $perms; $pname .= ' -> ' . readlink($_); } - elsif (-c _) { $perms = 'c' . $perms; $size = sizemm($rdev); } - elsif (-b _) { $perms = 'b' . $perms; $size = sizemm($rdev); } - elsif (-p _) { $perms = 'p' . $perms; } - elsif (-S _) { $perms = 's' . $perms; } - else { $perms = '?' . $perms; } - - my $user = $user{$uid} || $uid; - my $group = $group{$gid} || $gid; - - my ($sec,$min,$hour,$mday,$mon,$timeyear) = localtime($mtime); - if (-M _ > 365.25 / 2) { - $timeyear += 1900; - } else { - $timeyear = sprintf("%02d:%02d", $hour, $min); - } - - printf "%5lu %4ld %-10s %3d %-8s %-8s %8s %s %2d %5s %s\n", - $ino, - $blocks, - $perms, - $nlink, - $user, - $group, - $size, - $moname[$mon], - $mday, - $timeyear, - $pname; - 1; -} - -END -} - - -if (exists $init{cpio} || exists $init{tar}) { -print <<'END'; - -my %blocks = (); - -sub flush { - my ($fh, $varref, $blksz) = @_; - - while (length($$varref) >= $blksz) { - no strict qw/refs/; - syswrite($fh, $$varref, $blksz); - substr($$varref, 0, $blksz) = ''; - ++$blocks{$fh}; - } -} - -END -} - - -if (exists $init{cpio}) { - print <<'INTRO', <<"SUB", <<'END'; - -my %cpout = (); -my %nc = (); - -sub cpio { - my ($fh, $fname, $nc) = @_; - my $text = ''; - my ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size, - $atime,$mtime,$ctime,$blksize,$blocks); - local (*IN); - - if ( ! defined $fname ) { - $fname = 'TRAILER!!!'; - ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size, - $atime,$mtime,$ctime,$blksize,$blocks) = (0) x 13; - } else { - ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size, -INTRO - \$atime,\$mtime,\$ctime,\$blksize,\$blocks) = $stat(_); -SUB - if (-f _) { - open(IN, "./$_\0") || do { - warn "Couldn't open $fname: $!\n"; - return; - } - } else { - $text = readlink($_); - $size = 0 unless defined $text; - } - } - - $fname =~ s#^\./##; - $nc{$fh} = $nc; - if ($nc eq 'n') { - $cpout{$fh} .= - sprintf("%06o%06o%06o%06o%06o%06o%06o%06o%011lo%06o%011lo%s\0", - 070707, - $dev & 0777777, - $ino & 0777777, - $mode & 0777777, - $uid & 0777777, - $gid & 0777777, - $nlink & 0777777, - $rdev & 0177777, - $mtime, - length($fname)+1, - $size, - $fname); - } else { - $cpout{$fh} .= "\0" if length($cpout{$fh}) & 1; - $cpout{$fh} .= pack("SSSSSSSSLSLa*", - 070707, $dev, $ino, $mode, $uid, $gid, $nlink, $rdev, $mtime, - length($fname)+1, $size, - $fname . (length($fname) & 1 ? "\0" : "\0\0")); - } - - if ($text ne '') { - $cpout{$fh} .= $text; - } elsif ($size) { - my $l; - flush($fh, \$cpout{$fh}, 5120) - while ($l = length($cpout{$fh})) >= 5120; - while (sysread(IN, $cpout{$fh}, 5120 - $l, $l)) { - flush($fh, \$cpout{$fh}, 5120); - $l = length($cpout{$fh}); - } - close IN; - } -} - -sub cflushall () { - for my $fh (keys %cpout) { - cpio($fh, undef, $nc{$fh}); - $cpout{$fh} .= "0" x (5120 - length($cpout{$fh})); - flush($fh, \$cpout{$fh}, 5120); - print $blocks{$fh} * 10, " blocks\n"; - } -} - -END -} - -if (exists $init{tar}) { - print <<'INTRO', <<"SUB", <<'END'; - -my %tarout = (); -my %linkseen = (); - -sub tar { - my ($fh, $fname) = @_; - my $prefix = ''; - my $typeflag = '0'; - my $linkname; - my ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size, -INTRO - \$atime,\$mtime,\$ctime,\$blksize,\$blocks) = $stat(_); -SUB - local (*IN); - - if ($nlink > 1) { - if ($linkname = $linkseen{$fh, $dev, $ino}) { - if (length($linkname) > 100) { - warn "$0: omitting file with linkname ", - "too long for tar output: $linkname\n"; - return; - } - $typeflag = '1'; - $size = 0; - } else { - $linkseen{$fh, $dev, $ino} = $fname; - } - } - if ($typeflag eq '0') { - if (-f _) { - open(IN, "./$_\0") || do { - warn "Couldn't open $fname: $!\n"; - return; - } - } else { - $linkname = readlink($_); - if (defined $linkname) { $typeflag = '2' } - elsif (-c _) { $typeflag = '3' } - elsif (-b _) { $typeflag = '4' } - elsif (-d _) { $typeflag = '5' } - elsif (-p _) { $typeflag = '6' } - } - } - - if (length($fname) > 100) { - ($prefix, $fname) = ($fname =~ m#\A(.*?)/(.{,100})\Z(?!\n)#); - if (!defined($fname) || length($prefix) > 155) { - warn "$0: omitting file with name too long for tar output: ", - $fname, "\n"; - return; - } - } - - $size = 0 if $typeflag ne '0'; - my $header = pack("a100a8a8a8a12a12a8a1a100a6a2a32a32a8a8a155", - $fname, - sprintf("%7o ", $mode & 0777), - sprintf("%7o ", $uid & 0777777), - sprintf("%7o ", $gid & 0777777), - sprintf("%11o ", $size), - sprintf("%11o ", $mtime), - ' 'x8, - $typeflag, - defined $linkname ? $linkname : '', - "ustar\0", - "00", - $user{$uid}, - $group{$gid}, - ($rdev >> 8) & 0xff, - $rdev & 0xff, - $prefix, - ); - substr($header, 148, 8) = sprintf("%7o ", unpack("%16C*", $header)); - my $l = length($header) % 512; - $tarout{$fh} .= $header; - $tarout{$fh} .= "\0" x (512 - $l) if $l; - - if ($size) { - flush($fh, \$tarout{$fh}, 10240) - while ($l = length($tarout{$fh})) >= 10240; - while (sysread(IN, $tarout{$fh}, 10240 - $l, $l)) { - my $slop = length($tarout{$fh}) % 512; - $tarout{$fh} .= "\0" x (512 - $slop) if $slop; - flush($fh, \$tarout{$fh}, 10240); - $l = length($tarout{$fh}); - } - close IN; - } -} - -sub tflushall () { - my $len; - for my $fh (keys %tarout) { - $len = 10240 - length($tarout{$fh}); - $len += 10240 if $len < 1024; - $tarout{$fh} .= "\0" x $len; - flush($fh, \$tarout{$fh}, 10240); - } -} - -END -} - -exit; - -############################################################################ - -sub tab () { - my $tabstring; - - $tabstring = "\t" x ($indent_depth/2) . ' ' x ($indent_depth%2 * 4); - if (!$statdone) { - if ($_ =~ /^(?:name|print|prune|exec|ok|\(|\))/) { - $init{delayedstat} = 1; - } else { - my $statcall = '(($dev,$ino,$mode,$nlink,$uid,$gid) = ' - . $stat . '($_))'; - if (exists $init{saw_or}) { - $tabstring .= "(\$nlink || $statcall) &&\n" . $tabstring; - } else { - $tabstring .= "$statcall &&\n" . $tabstring; - } - $statdone = 1; - $init{declarestat} = 1; - } - } - $tabstring =~ s/^\s+/ / if $out =~ /!$/; - $tabstring; -} - -sub fileglob_to_re ($) { - my $x = shift; - $x =~ s#([./^\$()+])#\\$1#g; - $x =~ s#\*#.*#g; - $x =~ s#\?#.#g; - "^$x\\z"; -} - -sub n ($$) { - my ($pre, $n) = @_; - $n =~ s/^-/< / || $n =~ s/^\+/> / || $n =~ s/^/== /; - $n =~ s/ 0*(\d)/ $1/; - "($pre $n)"; -} - -sub quote ($) { - my $string = shift; - $string =~ s/\\/\\\\/g; - $string =~ s/'/\\'/g; - "'$string'"; -} - -__END__ - -=head1 NAME - -find2perl - translate find command lines to Perl code - -=head1 SYNOPSIS - - find2perl [paths] [predicates] | perl - -=head1 DESCRIPTION - -find2perl is a little translator to convert find command lines to -equivalent Perl code. The resulting code is typically faster than -running find itself. - -"paths" are a set of paths where find2perl will start its searches and -"predicates" are taken from the following list. - -=over 4 - -=item C<! PREDICATE> - -Negate the sense of the following predicate. The C<!> must be passed as -a distinct argument, so it may need to be surrounded by whitespace and/or -quoted from interpretation by the shell using a backslash (just as with -using C<find(1)>). - -=item C<( PREDICATES )> - -Group the given PREDICATES. The parentheses must be passed as distinct -arguments, so they may need to be surrounded by whitespace and/or -quoted from interpretation by the shell using a backslash (just as with -using C<find(1)>). - -=item C<PREDICATE1 PREDICATE2> - -True if _both_ PREDICATE1 and PREDICATE2 are true; PREDICATE2 is not -evaluated if PREDICATE1 is false. - -=item C<PREDICATE1 -o PREDICATE2> - -True if either one of PREDICATE1 or PREDICATE2 is true; PREDICATE2 is -not evaluated if PREDICATE1 is true. - -=item C<-follow> - -Follow (dereference) symlinks. The checking of file attributes depends -on the position of the C<-follow> option. If it precedes the file -check option, an C<stat> is done which means the file check applies to the -file the symbolic link is pointing to. If C<-follow> option follows the -file check option, this now applies to the symbolic link itself, i.e. -an C<lstat> is done. - -=item C<-depth> - -Change directory traversal algorithm from breadth-first to depth-first. - -=item C<-prune> - -Do not descend into the directory currently matched. - -=item C<-xdev> - -Do not traverse mount points (prunes search at mount-point directories). - -=item C<-name GLOB> - -File name matches specified GLOB wildcard pattern. GLOB may need to be -quoted to avoid interpretation by the shell (just as with using -C<find(1)>). - -=item C<-iname GLOB> - -Like C<-name>, but the match is case insensitive. - -=item C<-path GLOB> - -Path name matches specified GLOB wildcard pattern. - -=item C<-ipath GLOB> - -Like C<-path>, but the match is case insensitive. - -=item C<-perm PERM> - -Low-order 9 bits of permission match octal value PERM. - -=item C<-perm -PERM> - -The bits specified in PERM are all set in file's permissions. - -=item C<-type X> - -The file's type matches perl's C<-X> operator. - -=item C<-fstype TYPE> - -Filesystem of current path is of type TYPE (only NFS/non-NFS distinction -is implemented). - -=item C<-user USER> - -True if USER is owner of file. - -=item C<-group GROUP> - -True if file's group is GROUP. - -=item C<-nouser> - -True if file's owner is not in password database. - -=item C<-nogroup> - -True if file's group is not in group database. - -=item C<-inum INUM> - -True file's inode number is INUM. - -=item C<-links N> - -True if (hard) link count of file matches N (see below). - -=item C<-size N> - -True if file's size matches N (see below) N is normally counted in -512-byte blocks, but a suffix of "c" specifies that size should be -counted in characters (bytes) and a suffix of "k" specifies that -size should be counted in 1024-byte blocks. - -=item C<-atime N> - -True if last-access time of file matches N (measured in days) (see -below). - -=item C<-ctime N> - -True if last-changed time of file's inode matches N (measured in days, -see below). - -=item C<-mtime N> - -True if last-modified time of file matches N (measured in days, see below). - -=item C<-newer FILE> - -True if last-modified time of file matches N. - -=item C<-print> - -Print out path of file (always true). If none of C<-exec>, C<-ls>, -C<-print0>, or C<-ok> is specified, then C<-print> will be added -implicitly. - -=item C<-print0> - -Like -print, but terminates with \0 instead of \n. - -=item C<-exec OPTIONS ;> - -exec() the arguments in OPTIONS in a subprocess; any occurrence of {} in -OPTIONS will first be substituted with the path of the current -file. Note that the command "rm" has been special-cased to use perl's -unlink() function instead (as an optimization). The C<;> must be passed as -a distinct argument, so it may need to be surrounded by whitespace and/or -quoted from interpretation by the shell using a backslash (just as with -using C<find(1)>). - -=item C<-ok OPTIONS ;> - -Like -exec, but first prompts user; if user's response does not begin -with a y, skip the exec. The C<;> must be passed as -a distinct argument, so it may need to be surrounded by whitespace and/or -quoted from interpretation by the shell using a backslash (just as with -using C<find(1)>). - -=item C<-eval EXPR> - -Has the perl script eval() the EXPR. - -=item C<-ls> - -Simulates C<-exec ls -dils {} ;> - -=item C<-tar FILE> - -Adds current output to tar-format FILE. - -=item C<-cpio FILE> - -Adds current output to old-style cpio-format FILE. - -=item C<-ncpio FILE> - -Adds current output to "new"-style cpio-format FILE. - -=back - -Predicates which take a numeric argument N can come in three forms: - - * N is prefixed with a +: match values greater than N - * N is prefixed with a -: match values less than N - * N is not prefixed with either + or -: match only values equal to N - -=head1 SEE ALSO - -find, File::Find. - -=cut -!NO!SUBS! - -close OUT or die "Can't close $file: $!"; -chmod 0755, $file or die "Can't reset permissions for $file: $!\n"; -exec("$Config{'eunicefix'} $file") if $Config{'eunicefix'} ne ':'; -chdir $origdir; diff --git a/x2p/hash.c b/x2p/hash.c deleted file mode 100644 index 7d9c5ece85..0000000000 --- a/x2p/hash.c +++ /dev/null @@ -1,149 +0,0 @@ -/* hash.c - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1999, 2000, 2001, 2002, - * 2005 by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#include <stdio.h> -#include "EXTERN.h" -#include "a2p.h" -#include "util.h" - -#ifdef NETWARE -char *savestr(char *str); -#endif - -STR * -hfetch(HASH *tb, char *key) -{ - char *s; - int i; - int hash; - HENT *entry; - - if (!tb) - return NULL; - for (s=key, i=0, hash = 0; - /* while */ *s; - s++, i++, hash *= 5) { - hash += *s * coeff[i]; - } - entry = tb->tbl_array[hash & tb->tbl_max]; - for (; entry; entry = entry->hent_next) { - if (entry->hent_hash != hash) /* strings can't be equal */ - continue; - if (strNE(entry->hent_key,key)) /* is this it? */ - continue; - return entry->hent_val; - } - return NULL; -} - -bool -hstore(HASH *tb, char *key, STR *val) -{ - char *s; - int i; - int hash; - HENT *entry; - HENT **oentry; - - if (!tb) - return FALSE; - for (s=key, i=0, hash = 0; - /* while */ *s; - s++, i++, hash *= 5) { - hash += *s * coeff[i]; - } - - oentry = &(tb->tbl_array[hash & tb->tbl_max]); - i = 1; - - for (entry = *oentry; entry; i=0, entry = entry->hent_next) { - if (entry->hent_hash != hash) /* strings can't be equal */ - continue; - if (strNE(entry->hent_key,key)) /* is this it? */ - continue; - /*NOSTRICT*/ - safefree(entry->hent_val); - entry->hent_val = val; - return TRUE; - } - /*NOSTRICT*/ - entry = (HENT*) safemalloc(sizeof(HENT)); - - entry->hent_key = savestr(key); - entry->hent_val = val; - entry->hent_hash = hash; - entry->hent_next = *oentry; - *oentry = entry; - - if (i) { /* initial entry? */ - tb->tbl_fill++; - if ((tb->tbl_fill * 100 / (tb->tbl_max + 1)) > FILLPCT) - hsplit(tb); - } - - return FALSE; -} - -void -hsplit(HASH *tb) -{ - const int oldsize = tb->tbl_max + 1; - int newsize = oldsize * 2; - int i; - HENT **a; - HENT **b; - HENT *entry; - HENT **oentry; - - a = (HENT**) saferealloc((char*)tb->tbl_array, newsize * sizeof(HENT*)); - memset(&a[oldsize], 0, oldsize * sizeof(HENT*)); /* zero second half */ - tb->tbl_max = --newsize; - tb->tbl_array = a; - - for (i=0; i<oldsize; i++,a++) { - if (!*a) /* non-existent */ - continue; - b = a+oldsize; - for (oentry = a, entry = *a; entry; entry = *oentry) { - if ((entry->hent_hash & newsize) != i) { - *oentry = entry->hent_next; - entry->hent_next = *b; - if (!*b) - tb->tbl_fill++; - *b = entry; - continue; - } - else - oentry = &entry->hent_next; - } - if (!*a) /* everything moved */ - tb->tbl_fill--; - } -} - -HASH * -hnew(void) -{ - HASH *tb = (HASH*)safemalloc(sizeof(HASH)); - - tb->tbl_array = (HENT**) safemalloc(8 * sizeof(HENT*)); - tb->tbl_fill = 0; - tb->tbl_max = 7; - hiterinit(tb); /* so each() will start off right */ - memset(tb->tbl_array, 0, 8 * sizeof(HENT*)); - return tb; -} - -int -hiterinit(HASH *tb) -{ - tb->tbl_riter = -1; - tb->tbl_eiter = (HENT*)NULL; - return tb->tbl_fill; -} diff --git a/x2p/hash.h b/x2p/hash.h deleted file mode 100644 index ee5be5bab1..0000000000 --- a/x2p/hash.h +++ /dev/null @@ -1,47 +0,0 @@ -/* hash.h - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1999, 2000, 2005 - * by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#define FILLPCT 60 /* don't make greater than 99 */ - -#ifdef DOINIT -EXTERN_C char const coeff[] = { - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1, - 61,59,53,47,43,41,37,31,29,23,17,13,11,7,3,1}; -#else -EXTERN_C const char coeff[]; -#endif - -typedef struct hentry HENT; - -struct hentry { - HENT *hent_next; - char *hent_key; - STR *hent_val; - int hent_hash; -}; - -struct htbl { - HENT **tbl_array; - int tbl_max; - int tbl_fill; - int tbl_riter; /* current root of iterator */ - HENT *tbl_eiter; /* current entry of iterator */ -}; - -STR * hfetch ( HASH *tb, char *key ); -int hiterinit ( HASH *tb ); -HASH * hnew ( void ); -void hsplit ( HASH *tb ); -bool hstore ( HASH *tb, char *key, STR *val ); diff --git a/x2p/s2p.PL b/x2p/s2p.PL deleted file mode 100644 index 8a5abaeca8..0000000000 --- a/x2p/s2p.PL +++ /dev/null @@ -1,2072 +0,0 @@ -#!/usr/bin/perl - -use Config; -use File::Basename qw(&basename &dirname); -use Cwd; -use subs qw(link); - -sub link { # This is a cut-down version of installperl:link(). - my($from,$to) = @_; - my($success) = 0; - - eval { - CORE::link($from, $to) - ? $success++ - : ($from =~ m#^/afs/# || $to =~ m#^/afs/#) - ? die "AFS" # okay inside eval {} - : die "Couldn't link $from to $to: $!\n"; - }; - if ($@) { - require File::Copy; - File::Copy::copy($from, $to) - ? $success++ - : warn "Couldn't copy $from to $to: $!\n"; - } - $success; -} - -# List explicitly here the variables you want Configure to -# generate. Metaconfig only looks for shell variables, so you -# have to mention them as if they were shell variables, not -# %Config entries. Thus you write -# $startperl -# to ensure Configure will look for $Config{startperl}. - -# This forces PL files to create target in same directory as PL file. -# This is so that make depend always knows where to find PL derivatives. -$origdir = cwd; -chdir dirname($0); -$file = basename($0, '.PL'); -$file .= '.com' if $^O eq 'VMS'; - -open OUT,">$file" or die "Can't create $file: $!"; - -print "Extracting $file (with variable substitutions)\n"; - -# In this section, perl variables will be expanded during extraction. -# You can use $Config{...} to use Configure variables. - -print OUT <<"!GROK!THIS!"; -$Config{startperl} - eval 'exec $Config{perlpath} -S \$0 \${1+"\$@"}' - if \$running_under_some_shell; -my \$startperl; -my \$perlpath; -(\$startperl = <<'/../') =~ s/\\s*\\z//; -$Config{startperl} -/../ -(\$perlpath = <<'/../') =~ s/\\s*\\z//; -$Config{perlpath} -/../ -!GROK!THIS! - -# In the following, perl variables are not expanded during extraction. - -print OUT <<'!NO!SUBS!'; - -$0 =~ s/^.*?(\w+)[\.\w]*$/$1/; - -# (p)sed - a stream editor -# History: Aug 12 2000: Original version. -# Mar 25 2002: Rearrange generated Perl program. -# Jul 23 2007: Fix bug in regex stripping (M.Thorland) - -use strict; -use integer; -use Symbol; - -=head1 NAME - -psed - a stream editor - -=head1 SYNOPSIS - - psed [-an] script [file ...] - psed [-an] [-e script] [-f script-file] [file ...] - - s2p [-an] [-e script] [-f script-file] - -=head1 DESCRIPTION - -A stream editor reads the input stream consisting of the specified files -(or standard input, if none are given), processes is line by line by -applying a script consisting of edit commands, and writes resulting lines -to standard output. The filename 'C<->' may be used to read standard input. - -The edit script is composed from arguments of B<-e> options and -script-files, in the given order. A single script argument may be specified -as the first parameter. - -If this program is invoked with the name F<s2p>, it will act as a -sed-to-Perl translator. See L<"SED SCRIPT TRANSLATION">. - -B<sed> returns an exit code of 0 on success or >0 if an error occurred. - -=head1 OPTIONS - -=over 4 - -=item B<-a> - -A file specified as argument to the B<w> edit command is by default -opened before input processing starts. Using B<-a>, opening of such -files is delayed until the first line is actually written to the file. - -=item B<-e> I<script> - -The editing commands defined by I<script> are appended to the script. -Multiple commands must be separated by newlines. - -=item B<-f> I<script-file> - -Editing commands from the specified I<script-file> are read and appended -to the script. - -=item B<-n> - -By default, a line is written to standard output after the editing script -has been applied to it. The B<-n> option suppresses automatic printing. - -=back - -=head1 COMMANDS - -B<sed> command syntax is defined as - -Z<> Z<> Z<> Z<>[I<address>[B<,>I<address>]][B<!>]I<function>[I<argument>] - -with whitespace being permitted before or after addresses, and between -the function character and the argument. The I<address>es and the -address inverter (C<!>) are used to restrict the application of a -command to the selected line(s) of input. - -Each command must be on a line of its own, except where noted in -the synopses below. - -The edit cycle performed on each input line consist of reading the line -(without its trailing newline character) into the I<pattern space>, -applying the applicable commands of the edit script, writing the final -contents of the pattern space and a newline to the standard output. -A I<hold space> is provided for saving the contents of the -pattern space for later use. - -=head2 Addresses - -A sed address is either a line number or a pattern, which may be combined -arbitrarily to construct ranges. Lines are numbered across all input files. - -Any address may be followed by an exclamation mark ('C<!>'), selecting -all lines not matching that address. - -=over 4 - -=item I<number> - -The line with the given number is selected. - -=item B<$> - -A dollar sign (C<$>) is the line number of the last line of the input stream. - -=item B</>I<regular expression>B</> - -A pattern address is a basic regular expression (see -L<"BASIC REGULAR EXPRESSIONS">), between the delimiting character C</>. -Any other character except C<\> or newline may be used to delimit a -pattern address when the initial delimiter is prefixed with a -backslash ('C<\>'). - -=back - -If no address is given, the command selects every line. - -If one address is given, it selects the line (or lines) matching the -address. - -Two addresses select a range that begins whenever the first address -matches, and ends (including that line) when the second address matches. -If the first (second) address is a matching pattern, the second -address is not applied to the very same line to determine the end of -the range. Likewise, if the second address is a matching pattern, the -first address is not applied to the very same line to determine the -begin of another range. If both addresses are line numbers, -and the second line number is less than the first line number, then -only the first line is selected. - - -=head2 Functions - -The maximum permitted number of addresses is indicated with each -function synopsis below. - -The argument I<text> consists of one or more lines following the command. -Embedded newlines in I<text> must be preceded with a backslash. Other -backslashes in I<text> are deleted and the following character is taken -literally. - -=over 4 - -=cut - -my %ComTab; -my %GenKey; -#-------------------------------------------------------------------------- -$ComTab{'a'}=[ 1, 'txt', \&Emit, '{ push( @Q, <<'."'TheEnd' ) }\n" ]; #ok - -=item [1addr]B<a\> I<text> - -Write I<text> (which must start on the line following the command) -to standard output immediately before reading the next line -of input, either by executing the B<N> function or by beginning a new cycle. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'b'}=[ 2, 'str', \&Branch, '{ goto XXX; }' ]; #ok - -=item [2addr]B<b> [I<label>] - -Branch to the B<:> function with the specified I<label>. If no label -is given, branch to the end of the script. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'c'}=[ 2, 'txt', \&Change, <<'-X-' ]; #ok -{ print <<'TheEnd'; } $doPrint = 0; goto EOS; --X- -### continue OK => next CYCLE; - -=item [2addr]B<c\> I<text> - -The line, or range of lines, selected by the address is deleted. -The I<text> (which must start on the line following the command) -is written to standard output. With an address range, this occurs at -the end of the range. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'d'}=[ 2, '', \&Emit, <<'-X-' ]; #ok -{ $doPrint = 0; - goto EOS; -} --X- -### continue OK => next CYCLE; - -=item [2addr]B<d> - -Deletes the pattern space and starts the next cycle. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'D'}=[ 2, '', \&Emit, <<'-X-' ]; #ok -{ s/^.*\n?//; - if(length($_)){ goto BOS } else { goto EOS } -} --X- -### continue OK => next CYCLE; - -=item [2addr]B<D> - -Deletes the pattern space through the first embedded newline or to the end. -If the pattern space becomes empty, a new cycle is started, otherwise -execution of the script is restarted. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'g'}=[ 2, '', \&Emit, '{ $_ = $Hold };' ]; #ok - -=item [2addr]B<g> - -Replace the contents of the pattern space with the hold space. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'G'}=[ 2, '', \&Emit, '{ $_ .= "\n"; $_ .= $Hold };' ]; #ok - -=item [2addr]B<G> - -Append a newline and the contents of the hold space to the pattern space. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'h'}=[ 2, '', \&Emit, '{ $Hold = $_ }' ]; #ok - -=item [2addr]B<h> - -Replace the contents of the hold space with the pattern space. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'H'}=[ 2, '', \&Emit, '{ $Hold .= "\n"; $Hold .= $_; }' ]; #ok - -=item [2addr]B<H> - -Append a newline and the contents of the pattern space to the hold space. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'i'}=[ 1, 'txt', \&Emit, '{ print <<'."'TheEnd' }\n" ]; #ok - -=item [1addr]B<i\> I<text> - -Write the I<text> (which must start on the line following the command) -to standard output. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'l'}=[ 2, '', \&Emit, '{ _l() }' ]; #okUTF8 - -=item [2addr]B<l> - -Print the contents of the pattern space: non-printable characters are -shown in C-style escaped form; long lines are split and have a trailing -^'C<\>' at the point of the split; the true end of a line is marked with -a 'C<$>'. Escapes are: '\a', '\t', '\n', '\f', '\r', '\e' for -BEL, HT, LF, FF, CR, ESC, respectively, and '\' followed by a three-digit -octal number for all other non-printable characters. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'n'}=[ 2, '', \&Emit, <<'-X-' ]; #ok -{ print $_, "\n" if $doPrint; - printQ() if @Q; - $CondReg = 0; - last CYCLE unless getsARGV(); - chomp(); -} --X- - -=item [2addr]B<n> - -If automatic printing is enabled, write the pattern space to the standard -output. Replace the pattern space with the next line of input. If -there is no more input, processing is terminated. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'N'}=[ 2, '', \&Emit, <<'-X-' ]; #ok -{ printQ() if @Q; - $CondReg = 0; - last CYCLE unless getsARGV( $h ); - chomp( $h ); - $_ .= "\n$h"; -} --X- - -=item [2addr]B<N> - -Append a newline and the next line of input to the pattern space. If -there is no more input, processing is terminated. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'p'}=[ 2, '', \&Emit, '{ print $_, "\n"; }' ]; #ok - -=item [2addr]B<p> - -Print the pattern space to the standard output. (Use the B<-n> option -to suppress automatic printing at the end of a cycle if you want to -avoid double printing of lines.) - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'P'}=[ 2, '', \&Emit, <<'-X-' ]; #ok -{ if( /^(.*)/ ){ print $1, "\n"; } } --X- - -=item [2addr]B<P> - -Prints the pattern space through the first embedded newline or to the end. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'q'}=[ 1, '', \&Emit, <<'-X-' ]; #ok -{ print $_, "\n" if $doPrint; - last CYCLE; -} --X- - -=item [1addr]B<q> - -Branch to the end of the script and quit without starting a new cycle. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'r'}=[ 1, 'str', \&Emit, "{ _r( '-X-' ) }" ]; #ok - -=item [1addr]B<r> I<file> - -Copy the contents of the I<file> to standard output immediately before -the next attempt to read a line of input. Any error encountered while -reading I<file> is silently ignored. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'s'}=[ 2, 'sub', \&Emit, '' ]; #ok - -=item [2addr]B<s/>I<regular expression>B</>I<replacement>B</>I<flags> - -Substitute the I<replacement> string for the first substring in -the pattern space that matches the I<regular expression>. -Any character other than backslash or newline can be used instead of a -slash to delimit the regular expression and the replacement. -To use the delimiter as a literal character within the regular expression -and the replacement, precede the character by a backslash ('C<\>'). - -Literal newlines may be embedded in the replacement string by -preceding a newline with a backslash. - -Within the replacement, an ampersand ('C<&>') is replaced by the string -matching the regular expression. The strings 'C<\1>' through 'C<\9>' are -replaced by the corresponding subpattern (see L<"BASIC REGULAR EXPRESSIONS">). -To get a literal 'C<&>' or 'C<\>' in the replacement text, precede it -by a backslash. - -The following I<flags> modify the behaviour of the B<s> command: - -=over 8 - -=item B<g> - -The replacement is performed for all matching, non-overlapping substrings -of the pattern space. - -=item B<1>..B<9> - -Replace only the n-th matching substring of the pattern space. - -=item B<p> - -If the substitution was made, print the new value of the pattern space. - -=item B<w> I<file> - -If the substitution was made, write the new value of the pattern space -to the specified file. - -=back - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'t'}=[ 2, 'str', \&Branch, '{ goto XXX if _t() }' ]; #ok - -=item [2addr]B<t> [I<label>] - -Branch to the B<:> function with the specified I<label> if any B<s> -substitutions have been made since the most recent reading of an input line -or execution of a B<t> function. If no label is given, branch to the end of -the script. - - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'w'}=[ 2, 'str', \&Write, "{ _w( '-X-' ) }" ]; #ok - -=item [2addr]B<w> I<file> - -The contents of the pattern space are written to the I<file>. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'x'}=[ 2, '', \&Emit, '{ ($Hold, $_) = ($_, $Hold) }' ]; #ok - -=item [2addr]B<x> - -Swap the contents of the pattern space and the hold space. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'y'}=[ 2, 'tra', \&Emit, '' ]; #ok - -=item [2addr]B<y>B</>I<string1>B</>I<string2>B</> - -In the pattern space, replace all characters occurring in I<string1> by the -character at the corresponding position in I<string2>. It is possible -to use any character (other than a backslash or newline) instead of a -slash to delimit the strings. Within I<string1> and I<string2>, a -backslash followed by any character other than a newline is that literal -character, and a backslash followed by an 'n' is replaced by a newline -character. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'='}=[ 1, '', \&Emit, '{ print "$.\n" }' ]; #ok - -=item [1addr]B<=> - -Prints the current line number on the standard output. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{':'}=[ 0, 'str', \&Label, '' ]; #ok - -=item [0addr]B<:> [I<label>] - -The command specifies the position of the I<label>. It has no other effect. - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'{'}=[ 2, '', \&BeginBlock, '{' ]; #ok -$ComTab{'}'}=[ 0, '', \&EndBlock, ';}' ]; #ok -# ';' to avoid warning on empty {}-block - -=item [2addr]B<{> [I<command>] - -=item [0addr]B<}> - -These two commands begin and end a command list. The first command may -be given on the same line as the opening B<{> command. The commands -within the list are jointly selected by the address(es) given on the -B<{> command (but may still have individual addresses). - -=cut - -#-------------------------------------------------------------------------- -$ComTab{'#'}=[ 0, 'str', \&Comment, '' ]; #ok - -=item [0addr]B<#> [I<comment>] - -The entire line is ignored (treated as a comment). If, however, the first -two characters in the script are 'C<#n>', automatic printing of output is -suppressed, as if the B<-n> option were given on the command line. - -=back - -=cut - -use vars qw{ $isEOF $Hold %wFiles @Q $CondReg $doPrint }; - -my $useDEBUG = exists( $ENV{PSEDDEBUG} ); -my $useEXTBRE = $ENV{PSEDEXTBRE} || ''; -$useEXTBRE =~ s/[^<>wWyB]//g; # gawk RE's handle these - -my $doAutoPrint = 1; # automatic printing of pattern space (-n => 0) -my $doOpenWrite = 1; # open w command output files at start (-a => 0) -my $svOpenWrite = 0; # save $doOpenWrite - -# lower case $0 below as a VMSism. The VMS build procedure creates the -# s2p file traditionally in upper case on the disk. When VMS is in a -# case preserved or case sensitive mode, $0 will be returned in the exact -# case which will be on the disk, and that is not predictable at this time. - -my $doGenerate = lc($0) eq 's2p'; - -# Collected and compiled script -# -my( @Commands, %Defined, @BlockStack, %Label, $labNum, $Code, $Func ); -$Code = ''; - -################## -# Compile Time -# -# Labels -# -# Error handling -# -sub Warn($;$){ - my( $msg, $loc ) = @_; - $loc ||= ''; - $loc .= ': ' if length( $loc ); - warn( "$0: $loc$msg\n" ); -} - -$labNum = 0; -sub newLabel(){ - return 'L_'.++$labNum; -} - -# safeHere: create safe here delimiter and modify opcode and argument -# -sub safeHere($$){ - my( $codref, $argref ) = @_; - my $eod = 'EOD000'; - while( $$argref =~ /^$eod$/m ){ - $eod++; - } - $$codref =~ s/TheEnd/$eod/e; - $$argref .= "$eod\n"; -} - -# Emit: create address logic and emit command -# -sub Emit($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $arg, $fl ) = @_; - my $cond = ''; - if( defined( $addr1 ) ){ - if( defined( $addr2 ) ){ - $addr1 .= $addr2 =~ /^\d+$/ ? "..$addr2" : "...$addr2"; - } else { - $addr1 .= ' == $.' if $addr1 =~ /^\d+$/; - } - $cond = $negated ? "unless( $addr1 )\n" : "if( $addr1 )\n"; - } - - if( $opcode eq '' ){ - $Code .= "$cond$arg\n"; - - } elsif( $opcode =~ s/-X-/$arg/e ){ - $Code .= "$cond$opcode\n"; - - } elsif( $opcode =~ /TheEnd/ ){ - safeHere( \$opcode, \$arg ); - $Code .= "$cond$opcode$arg"; - - } else { - $Code .= "$cond$opcode\n"; - } - 0; -} - -# Write (w command, w flag): store pathname -# -sub Write($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $path, $fl ) = @_; - $wFiles{$path} = ''; - Emit( $addr1, $addr2, $negated, $opcode, $path, $fl ); -} - - -# Label (: command): label definition -# -sub Label($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $lab, $fl ) = @_; - my $rc = 0; - $lab =~ s/\s+//; - if( length( $lab ) ){ - my $h; - if( ! exists( $Label{$lab} ) ){ - $h = $Label{$lab}{name} = newLabel(); - } else { - $h = $Label{$lab}{name}; - if( exists( $Label{$lab}{defined} ) ){ - my $dl = $Label{$lab}{defined}; - Warn( "duplicate label $lab (first defined at $dl)", $fl ); - $rc = 1; - } - } - $Label{$lab}{defined} = $fl; - $Code .= "$h:;\n"; - } - $rc; -} - -# BeginBlock ({ command): push block start -# -sub BeginBlock($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $arg, $fl ) = @_; - push( @BlockStack, [ $fl, $addr1, $addr2, $negated ] ); - Emit( $addr1, $addr2, $negated, $opcode, $arg, $fl ); -} - -# EndBlock (} command): check proper nesting -# -sub EndBlock($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $arg, $fl ) = @_; - my $rc; - my $jcom = pop( @BlockStack ); - if( defined( $jcom ) ){ - $rc = Emit( $addr1, $addr2, $negated, $opcode, $arg, $fl ); - } else { - Warn( "unexpected '}'", $fl ); - $rc = 1; - } - $rc; -} - -# Branch (t, b commands): check or create label, substitute default -# -sub Branch($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $lab, $fl ) = @_; - $lab =~ s/\s+//; # no spaces at end - my $h; - if( length( $lab ) ){ - if( ! exists( $Label{$lab} ) ){ - $h = $Label{$lab}{name} = newLabel(); - } else { - $h = $Label{$lab}{name}; - } - push( @{$Label{$lab}{used}}, $fl ); - } else { - $h = 'EOS'; - } - $opcode =~ s/XXX/$h/e; - Emit( $addr1, $addr2, $negated, $opcode, '', $fl ); -} - -# Change (c command): is special due to range end watching -# -sub Change($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $arg, $fl ) = @_; - my $kwd = $negated ? 'unless' : 'if'; - if( defined( $addr2 ) ){ - $addr1 .= $addr2 =~ /^\d+$/ ? "..$addr2" : "...$addr2"; - if( ! $negated ){ - $addr1 = '$icnt = ('.$addr1.')'; - $opcode = 'if( $icnt =~ /E0$/ )' . $opcode; - } - } else { - $addr1 .= ' == $.' if $addr1 =~ /^\d+$/; - } - safeHere( \$opcode, \$arg ); - $Code .= "$kwd( $addr1 ){\n $opcode$arg}\n"; - 0; -} - - -# Comment (# command): A no-op. Who would've thought that! -# -sub Comment($$$$$$){ - my( $addr1, $addr2, $negated, $opcode, $arg, $fl ) = @_; -### $Code .= "# $arg\n"; - 0; -} - -# stripRegex from the current command. If we're in the first -# part of s///, trailing spaces have to be kept as the initial -# part of the replacement string. -# -sub stripRegex($$;$){ - my( $del, $sref, $sub ) = @_; - my $regex = $del; - print "stripRegex:$del:$$sref:\n" if $useDEBUG; - while( $$sref =~ s{^(.*?)(\\*)\Q$del\E(\s*)}{}s ){ - my $sl = $2; - $regex .= $1.$sl.$del; - if( length( $sl ) % 2 == 0 ){ - if( $sub && (length( $3 ) > 0) ){ - $$sref = $3 . $$sref; - } - return $regex; - } - $regex .= $3; - } - undef(); -} - -# stripTrans: take a <del> terminated string from y command -# honoring and cleaning up of \-escaped <del>'s -# -sub stripTrans($$){ - my( $del, $sref ) = @_; - my $t = ''; - print "stripTrans:$del:$$sref:\n" if $useDEBUG; - while( $$sref =~ s{^(.*?)(\\*)\Q$del\E}{}s ){ - my $sl = $2; - $t .= $1; - if( length( $sl ) % 2 == 0 ){ - $t .= $sl; - $t =~ s/\\\\/\\/g; - return $t; - } - chop( $sl ); - $t .= $sl.$del.$3; - } - undef(); -} - -# makey - construct Perl y/// from sed y/// -# -sub makey($$$){ - my( $fr, $to, $fl ) = @_; - my $error = 0; - - # Ensure that any '-' is up front. - # Diagnose duplicate contradicting mappings - my %tr; - for( my $i = 0; $i < length($fr); $i++ ){ - my $fc = substr($fr,$i,1); - my $tc = substr($to,$i,1); - if( exists( $tr{$fc} ) && $tr{$fc} ne $tc ){ - Warn( "ambiguous translation for character '$fc' in 'y' command", - $fl ); - $error++; - } - $tr{$fc} = $tc; - } - $fr = $to = ''; - if( exists( $tr{'-'} ) ){ - ( $fr, $to ) = ( '-', $tr{'-'} ); - delete( $tr{'-'} ); - } else { - $fr = $to = ''; - } - # might just as well sort it... - for my $fc ( sort keys( %tr ) ){ - $fr .= $fc; - $to .= $tr{$fc}; - } - # make embedded delimiters and newlines safe - $fr =~ s/([{}])/\$1/g; - $to =~ s/([{}])/\$1/g; - $fr =~ s/\n/\\n/g; - $to =~ s/\n/\\n/g; - return $error ? undef() : "{ y{$fr}{$to}; }"; -} - -###### -# makes - construct Perl s/// from sed s/// -# -sub makes($$$$$$$){ - my( $regex, $subst, $path, $global, $print, $nmatch, $fl ) = @_; - - # make embedded newlines safe - $regex =~ s/\n/\\n/g; - $subst =~ s/\n/\\n/g; - - my $code; - # n-th occurrence - # - if( length( $nmatch ) ){ - $code = <<TheEnd; -{ \$n = $nmatch; - while( --\$n && ( \$s = m ${regex}g ) ){} - \$s = ( substr( \$_, pos() ) =~ s ${regex}${subst}s ) if \$s; - \$CondReg ||= \$s; -TheEnd - } else { - $code = <<TheEnd; -{ \$s = s ${regex}${subst}s${global}; - \$CondReg ||= \$s; -TheEnd - } - if( $print ){ - $code .= ' print $_, "\n" if $s;'."\n"; - } - if( defined( $path ) ){ - $wFiles{$path} = ''; - $code .= " _w( '$path' ) if \$s;\n"; - $GenKey{'w'} = 1; - } - $code .= "}"; -} - -=head1 BASIC REGULAR EXPRESSIONS - -A I<Basic Regular Expression> (BRE), as defined in POSIX 1003.2, consists -of I<atoms>, for matching parts of a string, and I<bounds>, specifying -repetitions of a preceding atom. - -=head2 Atoms - -The possible atoms of a BRE are: B<.>, matching any single character; -B<^> and B<$>, matching the null string at the beginning or end -of a string, respectively; a I<bracket expressions>, enclosed -in B<[> and B<]> (see below); and any single character with no -other significance (matching that character). A B<\> before one -of: B<.>, B<^>, B<$>, B<[>, B<*>, B<\>, matching the character -after the backslash. A sequence of atoms enclosed in B<\(> and B<\)> -becomes an atom and establishes the target for a I<backreference>, -consisting of the substring that actually matches the enclosed atoms. -Finally, B<\> followed by one of the digits B<0> through B<9> is a -backreference. - -A B<^> that is not first, or a B<$> that is not last does not have -a special significance and need not be preceded by a backslash to -become literal. The same is true for a B<]>, that does not terminate -a bracket expression. - -An unescaped backslash cannot be last in a BRE. - -=head2 Bounds - -The BRE bounds are: B<*>, specifying 0 or more matches of the preceding -atom; B<\{>I<count>B<\}>, specifying that many repetitions; -B<\{>I<minimum>B<,\}>, giving a lower limit; and -B<\{>I<minimum>B<,>I<maximum>B<\}> finally defines a lower and upper -bound. - -A bound appearing as the first item in a BRE is taken literally. - -=head2 Bracket Expressions - -A I<bracket expression> is a list of characters, character ranges -and character classes enclosed in B<[> and B<]> and matches any -single character from the represented set of characters. - -A character range is written as two characters separated by B<-> and -represents all characters (according to the character collating sequence) -that are not less than the first and not greater than the second. -(Ranges are very collating-sequence-dependent, and portable programs -should avoid relying on them.) - -A character class is one of the class names - - alnum digit punct - alpha graph space - blank lower upper - cntrl print xdigit - -enclosed in B<[:> and B<:]> and represents the set of characters -as defined in ctype(3). - -If the first character after B<[> is B<^>, the sense of matching is -inverted. - -To include a literal 'C<^>', place it anywhere else but first. To -include a literal 'C<]>' place it first or immediately after an -initial B<^>. To include a literal 'C<->' make it the first (or -second after B<^>) or last character, or the second endpoint of -a range. - -The special bracket expression constructs C<[[:E<lt>:]]> and C<[[:E<gt>:]]> -match the null string at the beginning and end of a word respectively. -(Note that neither is identical to Perl's '\b' atom.) - -=head2 Additional Atoms - -Since some sed implementations provide additional regular expression -atoms (not defined in POSIX 1003.2), B<psed> is capable of translating -the following backslash escapes: - -=over 4 - -=item B<\E<lt>> This is the same as C<[[:E<gt>:]]>. - -=item B<\E<gt>> This is the same as C<[[:E<lt>:]]>. - -=item B<\w> This is an abbreviation for C<[[:alnum:]_]>. - -=item B<\W> This is an abbreviation for C<[^[:alnum:]_]>. - -=item B<\y> Match the empty string at a word boundary. - -=item B<\B> Match the empty string between any two either word or non-word characters. - -=back - -To enable this feature, the environment variable PSEDEXTBRE must be set -to a string containing the requested characters, e.g.: -C<PSEDEXTBRE='E<lt>E<gt>wW'>. - -=cut - -##### -# bre2p - convert BRE to Perl RE -# -sub peek(\$$){ - my( $pref, $ic ) = @_; - $ic < length($$pref)-1 ? substr( $$pref, $ic+1, 1 ) : ''; -} - -sub bre2p($$$){ - my( $del, $pat, $fl ) = @_; - my $led = $del; - $led =~ tr/{([</})]>/; - $led = '' if $led eq $del; - - $pat = substr( $pat, 1, length($pat) - 2 ); - my $res = ''; - my $bracklev = 0; - my $backref = 0; - my $parlev = 0; - for( my $ic = 0; $ic < length( $pat ); $ic++ ){ - my $c = substr( $pat, $ic, 1 ); - if( $c eq '\\' ){ - ### backslash escapes - my $nc = peek($pat,$ic); - if( $nc eq '' ){ - Warn( "'\\' cannot be last in pattern", $fl ); - return undef(); - } - $ic++; - if( $nc eq $del ){ ## \<pattern del> => \<pattern del> - $res .= "\\$del"; - - } elsif( $nc =~ /([[.*\\n])/ ){ - ## check for \-escaped magics and \n: - ## \[ \. \* \\ \n stay as they are - $res .= '\\'.$nc; - - } elsif( $nc eq '(' ){ ## \( => ( - $parlev++; - $res .= '('; - - } elsif( $nc eq ')' ){ ## \) => ) - $parlev--; - $backref++; - if( $parlev < 0 ){ - Warn( "unmatched '\\)'", $fl ); - return undef(); - } - $res .= ')'; - - } elsif( $nc eq '{' ){ ## repetition factor \{<i>[,[<j>]]\} - my $endpos = index( $pat, '\\}', $ic ); - if( $endpos < 0 ){ - Warn( "unmatched '\\{'", $fl ); - return undef(); - } - my $rep = substr( $pat, $ic+1, $endpos-($ic+1) ); - $ic = $endpos + 1; - - if( $res =~ /^\^?$/ ){ - $res .= "\\{$rep\}"; - } elsif( $rep =~ /^(\d+)(,?)(\d*)?$/ ){ - my $min = $1; - my $com = $2 || ''; - my $max = $3; - if( length( $max ) ){ - if( $max < $min ){ - Warn( "maximum less than minimum in '\\{$rep\\}'", - $fl ); - return undef(); - } - } else { - $max = ''; - } - # simplify some - if( $min == 0 && $max eq '1' ){ - $res .= '?'; - } elsif( $min == 1 && "$com$max" eq ',' ){ - $res .= '+'; - } elsif( $min == 0 && "$com$max" eq ',' ){ - $res .= '*'; - } else { - $res .= "{$min$com$max}"; - } - } else { - Warn( "invalid repeat clause '\\{$rep\\}'", $fl ); - return undef(); - } - - } elsif( $nc =~ /^[1-9]$/ ){ - ## \1 .. \9 => \1 .. \9, but check for a following digit - if( $nc > $backref ){ - Warn( "invalid backreference ($nc)", $fl ); - return undef(); - } - $res .= "\\$nc"; - if( peek($pat,$ic) =~ /[0-9]/ ){ - $res .= '(?:)'; - } - - } elsif( $useEXTBRE && ( $nc =~ /[$useEXTBRE]/ ) ){ - ## extensions - at most <>wWyB - not in POSIX - if( $nc eq '<' ){ ## \< => \b(?=\w), be precise - $res .= '\\b(?<=\\W)'; - } elsif( $nc eq '>' ){ ## \> => \b(?=\W), be precise - $res .= '\\b(?=\\W)'; - } elsif( $nc eq 'y' ){ ## \y => \b - $res .= '\\b'; - } else { ## \B, \w, \W remain the same - $res .= "\\$nc"; - } - } elsif( $nc eq $led ){ - ## \<closing bracketing-delimiter> - keep '\' - $res .= "\\$nc"; - - } else { ## \ <char> => <char> ("as if '\' were not present") - $res .= $nc; - } - - } elsif( $c eq '.' ){ ## . => . - $res .= $c; - - } elsif( $c eq '*' ){ ## * => * but \* if there's nothing preceding it - if( $res =~ /^\^?$/ ){ - $res .= '\\*'; - } elsif( substr( $res, -1, 1 ) ne '*' ){ - $res .= $c; - } - - } elsif( $c eq '[' ){ - ## parse []: [^...] [^]...] [-...] - my $add = '['; - if( peek($pat,$ic) eq '^' ){ - $ic++; - $add .= '^'; - } - my $nc = peek($pat,$ic); - if( $nc eq ']' || $nc eq '-' ){ - $add .= $nc; - $ic++; - } - # check that [ is not trailing - if( $ic >= length( $pat ) - 1 ){ - Warn( "unmatched '['", $fl ); - return undef(); - } - # look for [:...:] and x-y - my $rstr = substr( $pat, $ic+1 ); - if( $rstr =~ /^((?:\[:\(\w+|[><]\):\]|[^]-](?:-[^]])?)*)/ ){ - my $cnt = $1; - $ic += length( $cnt ); - $cnt =~ s/([\\\$])/\\$1/g; # '\', '$' are magic in Perl [] - # try some simplifications - my $red = $cnt; - if( $red =~ s/0-9// ){ - $cnt = $red.'\d'; - if( $red =~ s/A-Z// && $red =~ s/a-z// && $red =~ s/_// ){ - $cnt = $red.'\w'; - } - } - $add .= $cnt; - - # POSIX 1003.2 has this (optional) for begin/end word - $add = '\\b(?=\\W)' if $add eq '[[:<:]]'; - $add = '\\b(?<=\\W)' if $add eq '[[:>:]]'; - - } - - ## may have a trailing '-' before ']' - if( $ic < length($pat) - 1 && - substr( $pat, $ic+1 ) =~ /^(-?])/ ){ - $ic += length( $1 ); - $add .= $1; - # another simplification - $add =~ s/^\[(\^?)(\\[dw])]$/ $1 eq '^' ? uc($2) : $2 /e; - $res .= $add; - } else { - Warn( "unmatched '['", $fl ); - return undef(); - } - - } elsif( $c eq $led ){ ## unescaped <closing bracketing-delimiter> - $res .= "\\$c"; - - } elsif( $c eq ']' ){ ## unmatched ] is not magic - $res .= ']'; - - } elsif( $c =~ /[|+?{}()]/ ){ ## not magic in BRE, but in Perl: \-quote - $res .= "\\$c"; - - } elsif( $c eq '^' ){ ## not magic unless 1st, but in Perl: \-quote - $res .= length( $res ) ? '\\^' : '^'; - - } elsif( $c eq '$' ){ ## not magic unless last, but in Perl: \-quote - $res .= $ic == length( $pat ) - 1 ? '$' : '\\$'; - - } else { - $res .= $c; - } - } - - if( $parlev ){ - Warn( "unmatched '\\('", $fl ); - return undef(); - } - - # final cleanup: eliminate raw HTs - $res =~ s/\t/\\t/g; - return $del . $res . ( $led ? $led : $del ); -} - - -##### -# sub2p - convert sed substitution to Perl substitution -# -sub sub2p($$$){ - my( $del, $subst, $fl ) = @_; - my $led = $del; - $led =~ tr/{([</})]>/; - $led = '' if $led eq $del; - - $subst = substr( $subst, 1, length($subst) - 2 ); - my $res = ''; - - for( my $ic = 0; $ic < length( $subst ); $ic++ ){ - my $c = substr( $subst, $ic, 1 ); - if( $c eq '\\' ){ - ### backslash escapes - my $nc = peek($subst,$ic); - if( $nc eq '' ){ - Warn( "'\\' cannot be last in substitution", $fl ); - return undef(); - } - $ic++; - if( $nc =~ /[\\$del$led]/ ){ ## \ and delimiter - $res .= '\\' . $nc; - } elsif( $nc =~ /[1-9]/ ){ ## \1 - \9 => ${1} - ${9} - $res .= '${' . $nc . '}'; - } else { ## everything else (includes &): omit \ - $res .= $nc; - } - } elsif( $c eq '&' ){ ## & => $& - $res .= '$&'; - } elsif( $c =~ /[\$\@$led]/ ){ ## magic in Perl's substitution string - $res .= '\\' . $c; - } else { - $res .= $c; - } - } - - # final cleanup: eliminate raw HTs - $res =~ s/\t/\\t/g; - return ( $led ? $del : $led ) . $res . ( $led ? $led : $del ); -} - - -sub Parse(){ - my $error = 0; - my( $pdef, $pfil, $plin ); - for( my $icom = 0; $icom < @Commands; $icom++ ){ - my $cmd = $Commands[$icom]; - print "Parse:$cmd:\n" if $useDEBUG; - $cmd =~ s/^\s+//; - next unless length( $cmd ); - my $scom = $icom; - if( exists( $Defined{$icom} ) ){ - $pdef = $Defined{$icom}; - if( $pdef =~ /^ #(\d+)/ ){ - $pfil = 'expression #'; - $plin = $1; - } else { - $pfil = "$pdef l."; - $plin = 1; - } - } else { - $plin++; - } - my $fl = "$pfil$plin"; - - # insert command as comment in gnerated code - # - $Code .= "# $cmd\n" if $doGenerate; - - # The Address(es) - # - my( $negated, $naddr, $addr1, $addr2 ); - $naddr = 0; - if( $cmd =~ s/^(\d+)\s*// ){ - $addr1 = "$1"; $naddr++; - } elsif( $cmd =~ s/^\$\s*// ){ - $addr1 = 'eofARGV()'; $naddr++; - } elsif( $cmd =~ s{^(/)}{} || $cmd =~ s{^\\(.)}{} ){ - my $del = $1; - my $regex = stripRegex( $del, \$cmd ); - if( defined( $regex ) ){ - $addr1 = 'm '.bre2p( $del, $regex, $fl ).'s'; - $naddr++; - } else { - Warn( "malformed regex, 1st address", $fl ); - $error++; - next; - } - } - if( defined( $addr1 ) && $cmd =~ s/,\s*// ){ - if( $cmd =~ s/^(\d+)\s*// ){ - $addr2 = "$1"; $naddr++; - } elsif( $cmd =~ s/^\$\s*// ){ - $addr2 = 'eofARGV()'; $naddr++; - } elsif( $cmd =~ s{^(/)}{} || $cmd =~ s{^\\(.)}{} ){ - my $del = $1; - my $regex = stripRegex( $del, \$cmd ); - if( defined( $regex ) ){ - $addr2 = 'm '. bre2p( $del, $regex, $fl ).'s'; - $naddr++; - } else { - Warn( "malformed regex, 2nd address", $fl ); - $error++; - next; - } - } else { - Warn( "invalid address after ','", $fl ); - $error++; - next; - } - } - - # address modifier '!' - # - $negated = $cmd =~ s/^!\s*//; - if( defined( $addr1 ) ){ - print "Parse: addr1=$addr1" if $useDEBUG; - if( defined( $addr2 ) ){ - print ", addr2=$addr2 " if $useDEBUG; - # both numeric and addr1 > addr2 => eliminate addr2 - undef( $addr2 ) if $addr1 =~ /^\d+$/ && - $addr2 =~ /^\d+$/ && $addr1 > $addr2; - } - } - print 'negated' if $useDEBUG && $negated; - print " command:$cmd\n" if $useDEBUG; - - # The Command - # - if( $cmd !~ s/^([:#={}abcdDgGhHilnNpPqrstwxy])\s*// ){ - my $h = substr( $cmd, 0, 1 ); - Warn( "unknown command '$h'", $fl ); - $error++; - next; - } - my $key = $1; - - my $tabref = $ComTab{$key}; - $GenKey{$key} = 1; - if( $naddr > $tabref->[0] ){ - Warn( "excess address(es)", $fl ); - $error++; - next; - } - - my $arg = ''; - if( $tabref->[1] eq 'str' ){ - # take remainder - don't care if it is empty - $arg = $cmd; - $cmd = ''; - - } elsif( $tabref->[1] eq 'txt' ){ - # multi-line text - my $goon = $cmd =~ /(.*)\\$/; - if( length( $1 ) ){ - Warn( "extra characters after command ($cmd)", $fl ); - $error++; - } - while( $goon ){ - $icom++; - if( $icom > $#Commands ){ - Warn( "unexpected end of script", $fl ); - $error++; - last; - } - $cmd = $Commands[$icom]; - $Code .= "# $cmd\n" if $doGenerate; - $goon = $cmd =~ s/\\$//; - $cmd =~ s/\\(.)/$1/g; - $arg .= "\n" if length( $arg ); - $arg .= $cmd; - } - $arg .= "\n" if length( $arg ); - $cmd = ''; - - } elsif( $tabref->[1] eq 'sub' ){ - # s/// - if( ! length( $cmd ) ){ - Warn( "'s' command requires argument", $fl ); - $error++; - next; - } - if( $cmd =~ s{^([^\\\n])}{} ){ - my $del = $1; - my $regex = stripRegex( $del, \$cmd, "s" ); - if( ! defined( $regex ) ){ - Warn( "malformed regular expression", $fl ); - $error++; - next; - } - $regex = bre2p( $del, $regex, $fl ); - - # a trailing \ indicates embedded NL (in replacement string) - while( $cmd =~ s/(?<!\\)\\$/\n/ ){ - $icom++; - if( $icom > $#Commands ){ - Warn( "unexpected end of script", $fl ); - $error++; - last; - } - $cmd .= $Commands[$icom]; - $Code .= "# $Commands[$icom]\n" if $doGenerate; - } - - my $subst = stripRegex( $del, \$cmd ); - if( ! defined( $regex ) ){ - Warn( "malformed substitution expression", $fl ); - $error++; - next; - } - $subst = sub2p( $del, $subst, $fl ); - - # parse s/// modifier: g|p|0-9|w <file> - my( $global, $nmatch, $print, $write ) = - ( '', '', 0, undef ); - while( $cmd =~ s/^([gp0-9])// ){ - $1 eq 'g' ? ( $global = 'g' ) : - $1 eq 'p' ? ( $print = $1 ) : ( $nmatch .= $1 ); - } - $write = $1 if $cmd =~ s/w\s*(.*)$//; - ### $nmatch =~ s/^(\d)\1*$/$1/; ### may be dangerous? - if( $global && length( $nmatch ) || length( $nmatch ) > 1 ){ - Warn( "conflicting flags '$global$nmatch'", $fl ); - $error++; - next; - } - - $arg = makes( $regex, $subst, - $write, $global, $print, $nmatch, $fl ); - if( ! defined( $arg ) ){ - $error++; - next; - } - - } else { - Warn( "improper delimiter in s command", $fl ); - $error++; - next; - } - - } elsif( $tabref->[1] eq 'tra' ){ - # y/// - # a trailing \ indicates embedded newline - while( $cmd =~ s/(?<!\\)\\$/\n/ ){ - $icom++; - if( $icom > $#Commands ){ - Warn( "unexpected end of script", $fl ); - $error++; - last; - } - $cmd .= $Commands[$icom]; - $Code .= "# $Commands[$icom]\n" if $doGenerate; - } - if( ! length( $cmd ) ){ - Warn( "'y' command requires argument", $fl ); - $error++; - next; - } - my $d = substr( $cmd, 0, 1 ); $cmd = substr( $cmd, 1 ); - if( $d eq '\\' ){ - Warn( "'\\' not valid as delimiter in 'y' command", $fl ); - $error++; - next; - } - my $fr = stripTrans( $d, \$cmd ); - if( ! defined( $fr ) || ! length( $cmd ) ){ - Warn( "malformed 'y' command argument", $fl ); - $error++; - next; - } - my $to = stripTrans( $d, \$cmd ); - if( ! defined( $to ) ){ - Warn( "malformed 'y' command argument", $fl ); - $error++; - next; - } - if( length($fr) != length($to) ){ - Warn( "string lengths in 'y' command differ", $fl ); - $error++; - next; - } - if( ! defined( $arg = makey( $fr, $to, $fl ) ) ){ - $error++; - next; - } - - } - - # $cmd must be now empty - exception is { - if( $cmd !~ /^\s*$/ ){ - if( $key eq '{' ){ - # dirty hack to process command on '{' line - $Commands[$icom--] = $cmd; - } else { - Warn( "extra characters after command ($cmd)", $fl ); - $error++; - next; - } - } - - # Make Code - # - if( &{$tabref->[2]}( $addr1, $addr2, $negated, - $tabref->[3], $arg, $fl ) ){ - $error++; - } - } - - while( @BlockStack ){ - my $bl = pop( @BlockStack ); - Warn( "start of unterminated '{'", $bl ); - $error++; - } - - for my $lab ( keys( %Label ) ){ - if( ! exists( $Label{$lab}{defined} ) ){ - for my $used ( @{$Label{$lab}{used}} ){ - Warn( "undefined label '$lab'", $used ); - $error++; - } - } - } - - exit( 1 ) if $error; -} - - -############## -#### MAIN #### -############## - -sub usage(){ - print STDERR "Usage: sed [-an] command [file...]\n"; - print STDERR " [-an] [-e command] [-f script-file] [file...]\n"; -} - -################### -# Here we go again... -# -my $expr = 0; -while( @ARGV && $ARGV[0] =~ /^-(.)(.*)$/ ){ - my $opt = $1; - my $arg = $2; - shift( @ARGV ); - if( $opt eq 'e' ){ - if( length( $arg ) ){ - push( @Commands, split( "\n", $arg ) ); - } elsif( @ARGV ){ - push( @Commands, shift( @ARGV ) ); - } else { - Warn( "option -e requires an argument" ); - usage(); - exit( 1 ); - } - $expr++; - $Defined{$#Commands} = " #$expr"; - next; - } - if( $opt eq 'f' ){ - my $path; - if( length( $arg ) ){ - $path = $arg; - } elsif( @ARGV ){ - $path = shift( @ARGV ); - } else { - Warn( "option -f requires an argument" ); - usage(); - exit( 1 ); - } - my $fst = $#Commands + 1; - open( SCRIPT, "<$path" ) || die( "$0: $path: could not open ($!)\n" ); - my $cmd; - while( defined( $cmd = <SCRIPT> ) ){ - chomp( $cmd ); - push( @Commands, $cmd ); - } - close( SCRIPT ); - if( $#Commands >= $fst ){ - $Defined{$fst} = "$path"; - } - next; - } - if( $opt eq '-' && $arg eq '' ){ - last; - } - if( $opt eq 'h' || $opt eq '?' ){ - usage(); - exit( 0 ); - } - if( $opt eq 'n' ){ - $doAutoPrint = 0; - } elsif( $opt eq 'a' ){ - $doOpenWrite = 0; - } else { - Warn( "illegal option '$opt'" ); - usage(); - exit( 1 ); - } - if( length( $arg ) ){ - unshift( @ARGV, "-$arg" ); - } -} - -# A singleton command may be the 1st argument when there are no options. -# -if( @Commands == 0 ){ - if( @ARGV == 0 ){ - Warn( "no script command given" ); - usage(); - exit( 1 ); - } - push( @Commands, split( "\n", shift( @ARGV ) ) ); - $Defined{0} = ' #1'; -} - -print STDERR "Files: @ARGV\n" if $useDEBUG; - -# generate leading code -# -$Func = <<'[TheEnd]'; - -# openARGV: open 1st input file -# -sub openARGV(){ - unshift( @ARGV, '-' ) unless @ARGV; - my $file = shift( @ARGV ); - open( ARG, "<$file" ) - || die( "$0: can't open $file for reading ($!)\n" ); - $isEOF = 0; -} - -# getsARGV: Read another input line into argument (default: $_). -# Move on to next input file, and reset EOF flag $isEOF. -sub getsARGV(;\$){ - my $argref = @_ ? shift() : \$_; - while( $isEOF || ! defined( $$argref = <ARG> ) ){ - close( ARG ); - return 0 unless @ARGV; - my $file = shift( @ARGV ); - open( ARG, "<$file" ) - || die( "$0: can't open $file for reading ($!)\n" ); - $isEOF = 0; - } - 1; -} - -# eofARGV: end-of-file test -# -sub eofARGV(){ - return @ARGV == 0 && ( $isEOF = eof( ARG ) ); -} - -# makeHandle: Generates another file handle for some file (given by its path) -# to be written due to a w command or an s command's w flag. -sub makeHandle($){ - my( $path ) = @_; - my $handle; - if( ! exists( $wFiles{$path} ) || $wFiles{$path} eq '' ){ - $handle = $wFiles{$path} = gensym(); - if( $doOpenWrite ){ - if( ! open( $handle, ">$path" ) ){ - die( "$0: can't open $path for writing: ($!)\n" ); - } - } - } else { - $handle = $wFiles{$path}; - } - return $handle; -} - -# printQ: Print queued output which is either a string or a reference -# to a pathname. -sub printQ(){ - for my $q ( @Q ){ - if( ref( $q ) ){ - # flush open w files so that reading this file gets it all - if( exists( $wFiles{$$q} ) && $wFiles{$$q} ne '' ){ - open( $wFiles{$$q}, ">>$$q" ); - } - # copy file to stdout: slow, but safe - if( open( RF, "<$$q" ) ){ - while( defined( my $line = <RF> ) ){ - print $line; - } - close( RF ); - } - } else { - print $q; - } - } - undef( @Q ); -} - -[TheEnd] - -# generate the sed loop -# -$Code .= <<'[TheEnd]'; -sub openARGV(); -sub getsARGV(;\$); -sub eofARGV(); -sub printQ(); - -# Run: the sed loop reading input and applying the script -# -sub Run(){ - my( $h, $icnt, $s, $n ); - # hack (not unbreakable :-/) to avoid // matching an empty string - my $z = "\000"; $z =~ /$z/; - # Initialize. - openARGV(); - $Hold = ''; - $CondReg = 0; - $doPrint = $doAutoPrint; -CYCLE: - while( getsARGV() ){ - chomp(); - $CondReg = 0; # cleared on t -BOS:; -[TheEnd] - - # parse - avoid opening files when doing s2p - # - ( $svOpenWrite, $doOpenWrite ) = ( $doOpenWrite, $svOpenWrite ) - if $doGenerate; - Parse(); - ( $svOpenWrite, $doOpenWrite ) = ( $doOpenWrite, $svOpenWrite ) - if $doGenerate; - - # append trailing code - # - $Code .= <<'[TheEnd]'; -EOS: if( $doPrint ){ - print $_, "\n"; - } else { - $doPrint = $doAutoPrint; - } - printQ() if @Q; - } - - exit( 0 ); -} -[TheEnd] - - -# append optional functions, prepend prototypes -# -my $Proto = "# prototypes\n"; -if( $GenKey{'l'} ){ - $Proto .= "sub _l();\n"; - $Func .= <<'[TheEnd]'; -# _l: l command processing -# -sub _l(){ - my $h = $_; - my $mcpl = 70; - # transform non printing chars into escape notation - $h =~ s/\\/\\\\/g; - if( $h =~ /[^[:print:]]/ ){ - $h =~ s/\a/\\a/g; - $h =~ s/\f/\\f/g; - $h =~ s/\n/\\n/g; - $h =~ s/\t/\\t/g; - $h =~ s/\r/\\r/g; - $h =~ s/\e/\\e/g; - $h =~ s/([^[:print:]])/sprintf("\\%03o", ord($1))/ge; - } - # split into lines of length $mcpl - while( length( $h ) > $mcpl ){ - my $l = substr( $h, 0, $mcpl-1 ); - $h = substr( $h, $mcpl ); - # remove incomplete \-escape from end of line - if( $l =~ s/(?<!\\)(\\[0-7]{0,2})$// ){ - $h = $1 . $h; - } - print $l, "\\\n"; - } - print "$h\$\n"; -} - -[TheEnd] -} - -if( $GenKey{'r'} ){ - $Proto .= "sub _r(\$);\n"; - $Func .= <<'[TheEnd]'; -# _r: r command processing: Save a reference to the pathname. -# -sub _r($){ - my $path = shift(); - push( @Q, \$path ); -} - -[TheEnd] -} - -if( $GenKey{'t'} ){ - $Proto .= "sub _t();\n"; - $Func .= <<'[TheEnd]'; -# _t: t command - condition register test/reset -# -sub _t(){ - my $res = $CondReg; - $CondReg = 0; - $res; -} - -[TheEnd] -} - -if( $GenKey{'w'} ){ - $Proto .= "sub _w(\$);\n"; - $Func .= <<'[TheEnd]'; -# _w: w command and s command's w flag - write to file -# -sub _w($){ - my $path = shift(); - my $handle = $wFiles{$path}; - if( ! $doOpenWrite && ! defined( fileno( $handle ) ) ){ - open( $handle, ">$path" ) - || die( "$0: $path: cannot open ($!)\n" ); - } - print $handle $_, "\n"; -} - -[TheEnd] -} - -$Code = $Proto . $Code; - -# magic "#n" - same as -n option -# -$doAutoPrint = 0 if substr( $Commands[0], 0, 2 ) eq '#n'; - -# eval code - check for errors -# -print "Code:\n$Code$Func" if $useDEBUG; -eval $Code . $Func; -if( $@ ){ - print "Code:\n$Code$Func"; - die( "$0: internal error - generated incorrect Perl code: $@\n" ); -} - -if( $doGenerate ){ - - # write full Perl program - # - - # bang line, declarations, prototypes - print <<TheEnd; -#!$perlpath -w -eval 'exec $perlpath -S \$0 \${1+"\$@"}' - if 0; -\$0 =~ s/^.*?(\\w+)\[\\.\\w+\]*\$/\$1/; - -use strict; -use Symbol; -use vars qw{ \$isEOF \$Hold \%wFiles \@Q \$CondReg - \$doAutoPrint \$doOpenWrite \$doPrint }; -\$doAutoPrint = $doAutoPrint; -\$doOpenWrite = $doOpenWrite; -TheEnd - - my $wf = "'" . join( "', '", keys( %wFiles ) ) . "'"; - if( $wf ne "''" ){ - print <<TheEnd; -sub makeHandle(\$); -for my \$p ( $wf ){ - exit( 1 ) unless makeHandle( \$p ); -} -TheEnd - } - - print $Code; - print "Run();\n"; - print $Func; - exit( 0 ); - -} else { - - # execute: make handles (and optionally open) all w files; run! - for my $p ( keys( %wFiles ) ){ - exit( 1 ) unless makeHandle( $p ); - } - Run(); -} - - -=head1 ENVIRONMENT - -The environment variable C<PSEDEXTBRE> may be set to extend BREs. -See L<"Additional Atoms">. - -=head1 DIAGNOSTICS - -=over 4 - -=item ambiguous translation for character '%s' in 'y' command - -The indicated character appears twice, with different translations. - -=item '[' cannot be last in pattern - -A '[' in a BRE indicates the beginning of a I<bracket expression>. - -=item '\' cannot be last in pattern - -A '\' in a BRE is used to make the subsequent character literal. - -=item '\' cannot be last in substitution - -A '\' in a substitution string is used to make the subsequent character literal. - -=item conflicting flags '%s' - -In an B<s> command, either the 'g' flag and an n-th occurrence flag, or -multiple n-th occurrence flags are specified. Note that only the digits -^'1' through '9' are permitted. - -=item duplicate label %s (first defined at %s) - -=item excess address(es) - -The command has more than the permitted number of addresses. - -=item extra characters after command (%s) - -=item illegal option '%s' - -=item improper delimiter in s command - -The BRE and substitution may not be delimited with '\' or newline. - -=item invalid address after ',' - -=item invalid backreference (%s) - -The specified backreference number exceeds the number of backreferences -in the BRE. - -=item invalid repeat clause '\{%s\}' - -The repeat clause does not contain a valid integer value, or pair of -values. - -=item malformed regex, 1st address - -=item malformed regex, 2nd address - -=item malformed regular expression - -=item malformed substitution expression - -=item malformed 'y' command argument - -The first or second string of a B<y> command is syntactically incorrect. - -=item maximum less than minimum in '\{%s\}' - -=item no script command given - -There must be at least one B<-e> or one B<-f> option specifying a -script or script file. - -=item '\' not valid as delimiter in 'y' command - -=item option -e requires an argument - -=item option -f requires an argument - -=item 's' command requires argument - -=item start of unterminated '{' - -=item string lengths in 'y' command differ - -The translation table strings in a B<y> command must have equal lengths. - -=item undefined label '%s' - -=item unexpected '}' - -A B<}> command without a preceding B<{> command was encountered. - -=item unexpected end of script - -The end of the script was reached although a text line after a -B<a>, B<c> or B<i> command indicated another line. - -=item unknown command '%s' - -=item unterminated '[' - -A BRE contains an unterminated bracket expression. - -=item unterminated '\(' - -A BRE contains an unterminated backreference. - -=item '\{' without closing '\}' - -A BRE contains an unterminated bounds specification. - -=item '\)' without preceding '\(' - -=item 'y' command requires argument - -=back - -=head1 EXAMPLE - -The basic material for the preceding section was generated by running -the sed script - - #no autoprint - s/^.*Warn( *"\([^"]*\)".*$/\1/ - t process - b - :process - s/$!/%s/g - s/$[_[:alnum:]]\{1,\}/%s/g - s/\\\\/\\/g - s/^/=item / - p - -on the program's own text, and piping the output into C<sort -u>. - - -=head1 SED SCRIPT TRANSLATION - -If this program is invoked with the name F<s2p> it will act as a -sed-to-Perl translator. After option processing (all other -arguments are ignored), a Perl program is printed on standard -output, which will process the input stream (as read from all -arguments) in the way defined by the sed script and the option setting -used for the translation. - -=head1 SEE ALSO - -perl(1), re_format(7) - -=head1 BUGS - -The B<l> command will show escape characters (ESC) as 'C<\e>', but -a vertical tab (VT) in octal. - -Trailing spaces are truncated from labels in B<:>, B<t> and B<b> commands. - -The meaning of an empty regular expression ('C<//>'), as defined by B<sed>, -is "the last pattern used, at run time". This deviates from the Perl -interpretation, which will re-use the "last last successfully executed -regular expression". Since keeping track of pattern usage would create -terribly cluttered code, and differences would only appear in obscure -context (where other B<sed> implementations appear to deviate, too), -the Perl semantics was adopted. Note that common usage of this feature, -such as in C</abc/s//xyz/>, will work as expected. - -Collating elements (of bracket expressions in BREs) are not implemented. - -=head1 STANDARDS - -This B<sed> implementation conforms to the IEEE Std1003.2-1992 ("POSIX.2") -definition of B<sed>, and is compatible with the I<OpenBSD> -implementation, except where otherwise noted (see L<"BUGS">). - -=head1 AUTHOR - -This Perl implementation of I<sed> was written by Wolfgang Laun, -I<Wolfgang.Laun@alcatel.at>. - -=head1 COPYRIGHT and LICENSE - -This program is free and open software. You may use, modify, -distribute, and sell this program (and any modified variants) in any -way you wish, provided you do not restrict others from doing the same. - -=cut - -!NO!SUBS! - -close OUT or die "Can't close $file: $!"; -chmod 0755, $file or die "Can't reset permissions for $file: $!\n"; -unlink 'psed'; -print "Linking $file to psed.\n"; -if (defined $Config{d_link}) { - link $file, 'psed'; -} else { - unshift @INC, '../lib'; - require File::Copy; - File::Copy::syscopy('s2p', 'psed'); -} -exec("$Config{'eunicefix'} $file") if $Config{'eunicefix'} ne ':'; -chdir $origdir; diff --git a/x2p/str.c b/x2p/str.c deleted file mode 100644 index e12e5e9c12..0000000000 --- a/x2p/str.c +++ /dev/null @@ -1,260 +0,0 @@ -/* str.c - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1999, - * 2001, 2002, 2005 by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#include "EXTERN.h" -#include "a2p.h" -#include "util.h" - -void -str_numset(STR *str, double num) -{ - str->str_nval = num; - str->str_pok = 0; /* invalidate pointer */ - str->str_nok = 1; /* validate number */ -} - -char * -str_2ptr(STR *str) -{ - char *s; - - if (!str) - return (char *)""; /* probably safe - won't be written to */ - GROWSTR(&(str->str_ptr), &(str->str_len), 24); - s = str->str_ptr; - if (str->str_nok) { - sprintf(s,"%.20g",str->str_nval); - while (*s) s++; - } - *s = '\0'; - str->str_cur = s - str->str_ptr; - str->str_pok = 1; -#ifdef DEBUGGING - if (debug & 32) - fprintf(stderr,"0x%lx ptr(%s)\n",(unsigned long)str,str->str_ptr); -#endif - return str->str_ptr; -} - -void -str_sset(STR *dstr, STR *sstr) -{ - if (!sstr) - str_nset(dstr,No,0); - else if (sstr->str_nok) - str_numset(dstr,sstr->str_nval); - else if (sstr->str_pok) - str_nset(dstr,sstr->str_ptr,sstr->str_cur); - else - str_nset(dstr,"",0); -} - -void -str_nset(STR *str, const char *ptr, int len) -{ - GROWSTR(&(str->str_ptr), &(str->str_len), len + 1); - memcpy(str->str_ptr,ptr,len); - str->str_cur = len; - *(str->str_ptr+str->str_cur) = '\0'; - str->str_nok = 0; /* invalidate number */ - str->str_pok = 1; /* validate pointer */ -} - -void -str_set(STR *str, const char *ptr) -{ - int len; - - if (!ptr) - ptr = ""; - len = strlen(ptr); - GROWSTR(&(str->str_ptr), &(str->str_len), len + 1); - memcpy(str->str_ptr,ptr,len+1); - str->str_cur = len; - str->str_nok = 0; /* invalidate number */ - str->str_pok = 1; /* validate pointer */ -} - -void -str_ncat(STR *str, const char *ptr, int len) -{ - if (!(str->str_pok)) - str_2ptr(str); - GROWSTR(&(str->str_ptr), &(str->str_len), str->str_cur + len + 1); - memcpy(str->str_ptr+str->str_cur, ptr, len); - str->str_cur += len; - *(str->str_ptr+str->str_cur) = '\0'; - str->str_nok = 0; /* invalidate number */ - str->str_pok = 1; /* validate pointer */ -} - -void -str_scat(STR *dstr, STR *sstr) -{ - if (!(sstr->str_pok)) - str_2ptr(sstr); - if (sstr) - str_ncat(dstr,sstr->str_ptr,sstr->str_cur); -} - -void -str_cat(STR *str, const char *ptr) -{ - int len; - - if (!ptr) - return; - if (!(str->str_pok)) - str_2ptr(str); - len = strlen(ptr); - GROWSTR(&(str->str_ptr), &(str->str_len), str->str_cur + len + 1); - memcpy(str->str_ptr+str->str_cur, ptr, len+1); - str->str_cur += len; - str->str_nok = 0; /* invalidate number */ - str->str_pok = 1; /* validate pointer */ -} - -STR * -str_new(int len) -{ - STR *str; - - if (freestrroot) { - str = freestrroot; - freestrroot = str->str_link.str_next; - } - else { - str = (STR *) safemalloc(sizeof(STR)); - memset((char*)str,0,sizeof(STR)); - } - if (len) - GROWSTR(&(str->str_ptr), &(str->str_len), len + 1); - return str; -} - -/* make str point to what nstr did */ - -void -str_free(STR *str) -{ - if (!str) - return; - if (str->str_len) - str->str_ptr[0] = '\0'; - str->str_cur = 0; - str->str_nok = 0; - str->str_pok = 0; - str->str_link.str_next = freestrroot; - freestrroot = str; -} - -int -str_len(STR *str) -{ - if (!str) - return 0; - if (!(str->str_pok)) - str_2ptr(str); - if (str->str_len) - return str->str_cur; - else - return 0; -} - -char * -str_gets(STR *str, FILE *fp) -{ -#if defined(USE_STDIO_PTR) && defined(STDIO_PTR_LVALUE) && defined(STDIO_CNT_LVALUE) - /* Here is some breathtakingly efficient cheating */ - - char *bp; /* we're going to steal some values */ - int cnt; /* from the stdio struct and put EVERYTHING */ - STDCHAR *ptr; /* in the innermost loop into registers */ - char newline = '\n'; /* (assuming at least 6 registers) */ - int i; - int bpx; - -#if defined(VMS) - /* An ungetc()d char is handled separately from the regular - * buffer, so we getc() it back out and stuff it in the buffer. - */ - i = getc(fp); - if (i == EOF) return NULL; - *(--((*fp)->_ptr)) = (unsigned char) i; - (*fp)->_cnt++; -#endif - - cnt = FILE_cnt(fp); /* get count into register */ - str->str_nok = 0; /* invalidate number */ - str->str_pok = 1; /* validate pointer */ - if (str->str_len <= cnt) /* make sure we have the room */ - GROWSTR(&(str->str_ptr), &(str->str_len), cnt+1); - bp = str->str_ptr; /* move these two too to registers */ - ptr = (STDCHAR*)FILE_ptr(fp); - for (;;) { - while (--cnt >= 0) { - if ((*bp++ = *ptr++) == newline) { - if (bp <= str->str_ptr + 1 || bp[-2] != '\\') - goto thats_all_folks; - else { - line++; - bp -= 2; - } - } - } - - FILE_cnt(fp) = cnt; /* deregisterize cnt and ptr */ - FILE_ptr(fp) = ptr; - i = getc(fp); /* get more characters */ - cnt = FILE_cnt(fp); - ptr = (STDCHAR*)FILE_ptr(fp); /* reregisterize cnt and ptr */ - - bpx = bp - str->str_ptr; /* prepare for possible relocation */ - GROWSTR(&(str->str_ptr), &(str->str_len), str->str_cur + cnt + 1); - bp = str->str_ptr + bpx; /* reconstitute our pointer */ - - if (i == newline) { /* all done for now? */ - *bp++ = i; - goto thats_all_folks; - } - else if (i == EOF) /* all done for ever? */ - goto thats_all_folks; - *bp++ = i; /* now go back to screaming loop */ - } - -thats_all_folks: - FILE_cnt(fp) = cnt; /* put these back or we're in trouble */ - FILE_ptr(fp) = ptr; - *bp = '\0'; - str->str_cur = bp - str->str_ptr; /* set length */ - -#else /* USE_STDIO_PTR && STDIO_PTR_LVALUE && STDIO_CNT_LVALUE */ - /* The big, slow, and stupid way */ - - static char buf[4192]; - - if (fgets(buf, sizeof buf, fp) != NULL) - str_set(str, buf); - else - str_set(str, No); - -#endif /* USE_STDIO_PTR && STDIO_PTR_LVALUE && STDIO_CNT_LVALUE */ - - return str->str_cur ? str->str_ptr : NULL; -} - -STR * -str_make(const char *s) -{ - STR *str = str_new(0); - - str_set(str,s); - return str; -} - diff --git a/x2p/str.h b/x2p/str.h deleted file mode 100644 index 7fc8e1e3b4..0000000000 --- a/x2p/str.h +++ /dev/null @@ -1,41 +0,0 @@ -/* str.h - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1999, 2000, 2005 - * by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -struct string { - char * str_ptr; /* pointer to malloced string */ - double str_nval; /* numeric value, if any */ - int str_len; /* allocated size */ - int str_cur; /* length of str_ptr as a C string */ - union { - STR *str_next; /* while free, link to next free str */ - } str_link; - char str_pok; /* state of str_ptr */ - char str_nok; /* state of str_nval */ -}; - -/* the following macro updates any magic values this str is associated with */ - -#define STABSET(x) (x->str_link.str_magic && stabset(x->str_link.str_magic,x)) - -EXT STR **tmps_list; -EXT long tmps_max INIT(-1); - -char * str_2ptr ( STR *str ); -void str_cat ( STR *str, const char *ptr ); -void str_free ( STR *str ); -char * str_gets ( STR *str, FILE *fp ); -int str_len ( STR *str ); -STR * str_make ( const char *s ); -void str_ncat ( STR *str, const char *ptr, int len ); -STR * str_new ( int len ); -void str_nset ( STR *str, const char *ptr, int len ); -void str_numset ( STR *str, double num ); -void str_scat ( STR *dstr, STR *sstr ); -void str_set ( STR *str, const char *ptr ); -void str_sset ( STR *dstr, STR *sstr ); diff --git a/x2p/util.c b/x2p/util.c deleted file mode 100644 index 113c3818ff..0000000000 --- a/x2p/util.c +++ /dev/null @@ -1,196 +0,0 @@ -/* util.c - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1999, - * 2000, 2001, 2005 by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#include "EXTERN.h" -#include "a2p.h" -#include "INTERN.h" -#include "util.h" - -#include <stdarg.h> -#define FLUSH - -static const char nomem[] = "Out of memory!\n"; - -/* paranoid version of malloc */ - - -Malloc_t -safemalloc(MEM_SIZE size) -{ - Malloc_t ptr; - - /* malloc(0) is NASTY on some systems */ - ptr = malloc(size ? size : 1); -#ifdef DEBUGGING - if (debug & 128) - fprintf(stderr,"0x%lx: (%05d) malloc %ld bytes\n",(unsigned long)ptr, - an++,(long)size); -#endif - if (ptr != NULL) - return ptr; - else { - fputs(nomem,stdout) FLUSH; - exit(1); - } - /*NOTREACHED*/ - return 0; -} - -/* paranoid version of realloc */ - -Malloc_t -saferealloc(Malloc_t where, MEM_SIZE size) -{ - Malloc_t ptr; - - /* realloc(0) is NASTY on some systems */ - ptr = realloc(where, size ? size : 1); -#ifdef DEBUGGING - if (debug & 128) { - fprintf(stderr,"0x%lx: (%05d) rfree\n",(unsigned long)where,an++); - fprintf(stderr,"0x%lx: (%05d) realloc %ld bytes\n",(unsigned long)ptr,an++,(long)size); - } -#endif - if (ptr != NULL) - return ptr; - else { - fputs(nomem,stdout) FLUSH; - exit(1); - } - /*NOTREACHED*/ - return 0; -} - -/* safe version of free */ - -Free_t -safefree(Malloc_t where) -{ -#ifdef DEBUGGING - if (debug & 128) - fprintf(stderr,"0x%lx: (%05d) free\n",(unsigned long)where,an++); -#endif - free(where); -} - -/* copy a string up to some (non-backslashed) delimiter, if any */ - -char * -cpytill(char *to, char *from, int delim) -{ - for (; *from; from++,to++) { - if (*from == '\\') { - if (from[1] == delim) - from++; - else if (from[1] == '\\') - *to++ = *from++; - } - else if (*from == delim) - break; - *to = *from; - } - *to = '\0'; - return from; -} - - -char * -cpy2(char *to, char *from, int delim) -{ - for (; *from; from++,to++) { - if (*from == '\\') - *to++ = *from++; - else if (*from == '$') - *to++ = '\\'; - else if (*from == delim) - break; - *to = *from; - } - *to = '\0'; - return from; -} - -/* return ptr to little string in big string, NULL if not found */ - -char * -instr(char *big, const char *little) -{ - char *t, *x; - const char *s; - - for (t = big; *t; t++) { - for (x=t,s=little; *s; x++,s++) { - if (!*x) - return NULL; - if (*s != *x) - break; - } - if (!*s) - return t; - } - return NULL; -} - -/* copy a string to a safe spot */ - -char * -savestr(const char *str) -{ - char * const newaddr = (char *) safemalloc((MEM_SIZE)(strlen(str)+1)); - - (void)strcpy(newaddr,str); - return newaddr; -} - -/* grow a static string to at least a certain length */ - -void -growstr(char **strptr, int *curlen, int newlen) -{ - if (newlen > *curlen) { /* need more room? */ - if (*curlen) - *strptr = (char *) saferealloc(*strptr,(MEM_SIZE)newlen); - else - *strptr = (char *) safemalloc((MEM_SIZE)newlen); - *curlen = newlen; - } -} - -void -fatal(const char *pat,...) -{ -#if defined(HAS_VPRINTF) - va_list args; - - va_start(args, pat); - vfprintf(stderr,pat,args); - va_end(args); -#else - fprintf(stderr,pat,a1,a2,a3,a4); -#endif - exit(1); -} - -#if defined(DARWIN) -__private_extern__ /* warn() conflicts with libc */ -#endif -void -warn(const char *pat,...) -{ -#if defined(HAS_VPRINTF) - va_list args; - - va_start(args, pat); - vfprintf(stderr,pat,args); - va_end(args); -#else - fprintf(stderr,pat,a1,a2,a3,a4); -#endif -} - diff --git a/x2p/util.h b/x2p/util.h deleted file mode 100644 index 3330a60957..0000000000 --- a/x2p/util.h +++ /dev/null @@ -1,32 +0,0 @@ -/* util.h - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1996, 1999, 2000, 2005 - * by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -/* is the string for makedir a directory name or a filename? */ - -#define fatal Myfatal - -#define MD_DIR 0 -#define MD_FILE 1 - -#ifdef SETUIDGID - int eaccess(); -#endif - -char * cpy2 ( char *to, char *from, int delim ); -char * cpytill ( char *to, char *from, int delim ); -void growstr ( char **strptr, int *curlen, int newlen ); -char * instr ( char *big, const char *little ); -char * savestr ( const char *str ); -void fatal ( const char *pat, ... ); -void warn ( const char *pat, ... ); -int prewalk ( int numit, int level, int node, int *numericptr ); - -Malloc_t safemalloc (MEM_SIZE nbytes); -Malloc_t saferealloc (Malloc_t where, MEM_SIZE nbytes); -Free_t safefree (Malloc_t where); diff --git a/x2p/walk.c b/x2p/walk.c deleted file mode 100644 index d6962ede0f..0000000000 --- a/x2p/walk.c +++ /dev/null @@ -1,2055 +0,0 @@ -/* walk.c - * - * Copyright (C) 1991, 1992, 1993, 1994, 1995, 1997, 1998, 1999, - * 2000, 2001, 2002, 2005 by Larry Wall and others - * - * You may distribute under the terms of either the GNU General Public - * License or the Artistic License, as specified in the README file. - */ - -#include "EXTERN.h" -#include "a2p.h" -#include "util.h" - -bool exitval = FALSE; -bool realexit = FALSE; -bool saw_getline = FALSE; -bool subretnum = FALSE; -bool saw_FNR = FALSE; -bool saw_argv0 = FALSE; -bool saw_fh = FALSE; -int maxtmp = 0; -const char *lparen; -const char *rparen; -const char *limit; -STR *subs; -STR *curargs = NULL; - -static void addsemi ( STR *str ); -static void emit_split ( STR *str, int level ); -static void fixtab ( STR *str, int lvl ); -static void numericize ( int node ); -static void tab ( STR *str, int lvl ); - -int prewalk ( int numit, int level, int node, int *numericptr ); -STR * walk ( int useval, int level, int node, int *numericptr, int minprec ); -#ifdef NETWARE -char *savestr(char *str); -char *cpytill(char *to, char *from, int delim); -char *instr(char *big, const char *little); -#endif - -STR * -walk(int useval, int level, int node, int *numericptr, int minprec) -{ - int len; - STR *str; - int type; - int i; - STR *tmpstr; - STR *tmp2str; - STR *tmp3str; - char *t; - char *d, *s; - int numarg; - int numeric = FALSE; - STR *fstr; - int prec = P_MAX; /* assume no parens needed */ - - if (!node) { - *numericptr = 0; - return str_make(""); - } - type = ops[node].ival; - len = type >> 8; - type &= 255; - switch (type) { - case OPROG: - arymax = 0; - if (namelist) { - while (isALPHA(*namelist)) { - for (d = tokenbuf,s=namelist; - isWORDCHAR(*s); - *d++ = *s++) ; - *d = '\0'; - while (*s && !isALPHA(*s)) s++; - namelist = s; - nameary[++arymax] = savestr(tokenbuf); - } - } - if (maxfld < arymax) - maxfld = arymax; - opens = str_new(0); - subs = str_new(0); - str = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - if (do_split && need_entire && !absmaxfld) - split_to_array = TRUE; - if (fswitch && !const_FS) - const_FS = fswitch; - if (saw_FS > 1 || saw_RS) - const_FS = 0; - if (saw_ORS && need_entire) - do_chop = TRUE; - if (fswitch) { - str_cat(str,"$FS = '"); - if (strchr("*+?.[]()|^$\\",fswitch)) - str_cat(str,"\\"); - sprintf(tokenbuf,"%c",fswitch); - str_cat(str,tokenbuf); - str_cat(str,"';\t\t# field separator from -F switch\n"); - } - else if (saw_FS && !const_FS) { - str_cat(str,"$FS = ' ';\t\t# set field separator\n"); - } - if (saw_OFS) { - str_cat(str,"$, = ' ';\t\t# set output field separator\n"); - } - if (saw_ORS) { - str_cat(str,"$\\ = \"\\n\";\t\t# set output record separator\n"); - } - if (saw_argv0) { - str_cat(str,"$ARGV0 = $0;\t\t# remember what we ran as\n"); - } - if (str->str_cur > 20) - str_cat(str,"\n"); - if (ops[node+2].ival) { - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,"\n\n"); - } - fstr = walk(0,level+1,ops[node+3].ival,&numarg,P_MIN); - if (*fstr->str_ptr) { - if (saw_line_op) - str_cat(str,"line: "); - str_cat(str,"while (<>) {\n"); - tab(str,++level); - if (saw_FS && !const_FS) - do_chop = TRUE; - if (do_chop) { - str_cat(str,"chomp;\t# strip record separator\n"); - tab(str,level); - } - if (do_split) - emit_split(str,level); - str_scat(str,fstr); - str_free(fstr); - fixtab(str,--level); - str_cat(str,"}\n"); - if (saw_FNR) - str_cat(str,"continue {\n $FNRbase = $. if eof;\n}\n"); - } - else if (old_awk) - str_cat(str,"while (<>) { } # (no line actions)\n"); - if (ops[node+4].ival) { - realexit = TRUE; - str_cat(str,"\n"); - tab(str,level); - str_scat(str,fstr=walk(0,level,ops[node+4].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,"\n"); - } - if (exitval) - str_cat(str,"exit $ExitValue;\n"); - if (subs->str_ptr) { - str_cat(str,"\n"); - str_scat(str,subs); - } - if (saw_getline) { - for (len = 0; len < 4; len++) { - if (saw_getline & (1 << len)) { - sprintf(tokenbuf,"\nsub Getline%d {\n",len); - str_cat(str, tokenbuf); - if (len & 2) { - if (do_fancy_opens) - str_cat(str," &Pick('',@_);\n"); - else - str_cat(str," ($fh) = @_;\n"); - } - else { - if (saw_FNR) - str_cat(str," $FNRbase = $. if eof;\n"); - } - if (len & 1) - str_cat(str," local($_);\n"); - if (len & 2) - str_cat(str, - " if ($getline_ok = (($_ = <$fh>) ne ''))"); - else - str_cat(str, - " if ($getline_ok = (($_ = <>) ne ''))"); - str_cat(str, " {\n"); - level += 2; - tab(str,level); - i = 0; - if (do_chop) { - i++; - str_cat(str,"chomp;\t# strip record separator\n"); - tab(str,level); - } - if (do_split && !(len & 1)) { - i++; - emit_split(str,level); - } - if (!i) - str_cat(str,";\n"); - fixtab(str,--level); - str_cat(str,"}\n $_;\n}\n"); - --level; - } - } - } - if (do_fancy_opens) { - str_cat(str,"\n\ -sub Pick {\n\ - local($mode,$name,$pipe) = @_;\n\ - $fh = $name;\n\ - open($name,$mode.$name.$pipe) unless $opened{$name}++;\n\ -}\n\ -"); - } - break; - case OHUNKS: - str = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - if (len == 3) { - str_scat(str,fstr=walk(0,level,ops[node+3].ival,&numarg,P_MIN)); - str_free(fstr); - } - else { - } - break; - case ORANGE: - prec = P_DOTDOT; - str = walk(1,level,ops[node+1].ival,&numarg,prec+1); - str_cat(str," .. "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OPAT: - goto def; - case OREGEX: - str = str_new(0); - str_set(str,"/"); - tmpstr=walk(0,level,ops[node+1].ival,&numarg,P_MIN); - /* translate \nnn to [\nnn] */ - for (s = tmpstr->str_ptr, d = tokenbuf; *s; s++, d++) { - if (*s == '\\' && isDIGIT(s[1]) && isDIGIT(s[2]) && isDIGIT(s[3])){ - *d++ = '['; - *d++ = *s++; - *d++ = *s++; - *d++ = *s++; - *d++ = *s; - *d = ']'; - } - else - *d = *s; - } - *d = '\0'; - for (d=tokenbuf; *d; d++) - *d += (char)128; - str_cat(str,tokenbuf); - str_free(tmpstr); - str_cat(str,"/"); - break; - case OHUNK: - if (len == 1) { - str = walk(0,level,oper1(OPRINT,0),&numarg,P_MIN); - str_cat(str," if "); - str_scat(str,fstr=walk(0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,";"); - } - else { - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - if (*tmpstr->str_ptr) { - str = str_new(0); - str_set(str,"if ("); - str_scat(str,tmpstr); - str_cat(str,") {\n"); - tab(str,++level); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - fixtab(str,--level); - str_cat(str,"}\n"); - tab(str,level); - } - else { - str = walk(0,level,ops[node+2].ival,&numarg,P_MIN); - } - } - break; - case OPPAREN: - str = str_new(0); - str_set(str,"("); - str_scat(str,fstr=walk(useval != 0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,")"); - break; - case OPANDAND: - prec = P_ANDAND; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," && "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OPOROR: - prec = P_OROR; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," || "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OPNOT: - prec = P_UNARY; - str = str_new(0); - str_set(str,"!"); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,prec)); - str_free(fstr); - break; - case OCOND: - prec = P_COND; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," ? "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - str_cat(str," : "); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OCPAREN: - str = str_new(0); - str_set(str,"("); - str_scat(str,fstr=walk(useval != 0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - numeric |= numarg; - str_cat(str,")"); - break; - case OCANDAND: - prec = P_ANDAND; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - numeric = 1; - str_cat(str," && "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OCOROR: - prec = P_OROR; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - numeric = 1; - str_cat(str," || "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OCNOT: - prec = P_UNARY; - str = str_new(0); - str_set(str,"!"); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,prec)); - str_free(fstr); - numeric = 1; - break; - case ORELOP: - prec = P_REL; - str = walk(1,level,ops[node+2].ival,&numarg,prec+1); - numeric |= numarg; - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - tmp2str = walk(1,level,ops[node+3].ival,&numarg,prec+1); - numeric |= numarg; - if (!numeric || - (!numarg && (*tmp2str->str_ptr == '"' || *tmp2str->str_ptr == '\''))) { - t = tmpstr->str_ptr; - if (strEQ(t,"==")) - str_set(tmpstr,"eq"); - else if (strEQ(t,"!=")) - str_set(tmpstr,"ne"); - else if (strEQ(t,"<")) - str_set(tmpstr,"lt"); - else if (strEQ(t,"<=")) - str_set(tmpstr,"le"); - else if (strEQ(t,">")) - str_set(tmpstr,"gt"); - else if (strEQ(t,">=")) - str_set(tmpstr,"ge"); - if (!strchr(tmpstr->str_ptr,'\'') && !strchr(tmpstr->str_ptr,'"') && - !strchr(tmp2str->str_ptr,'\'') && !strchr(tmp2str->str_ptr,'"') ) - numeric |= 2; - } - if (numeric & 2) { - if (numeric & 1) /* numeric is very good guess */ - str_cat(str," "); - else - str_cat(str,"\377"); - numeric = 1; - } - else - str_cat(str," "); - str_scat(str,tmpstr); - str_free(tmpstr); - str_cat(str," "); - str_scat(str,tmp2str); - str_free(tmp2str); - numeric = 1; - break; - case ORPAREN: - str = str_new(0); - str_set(str,"("); - str_scat(str,fstr=walk(useval != 0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - numeric |= numarg; - str_cat(str,")"); - break; - case OMATCHOP: - prec = P_MATCH; - str = walk(1,level,ops[node+2].ival,&numarg,prec+1); - str_cat(str," "); - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - if (strEQ(tmpstr->str_ptr,"~")) - str_cat(str,"=~"); - else { - str_scat(str,tmpstr); - str_free(tmpstr); - } - str_cat(str," "); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OMPAREN: - str = str_new(0); - str_set(str,"("); - str_scat(str, - fstr=walk(useval != 0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - numeric |= numarg; - str_cat(str,")"); - break; - case OCONCAT: - prec = P_ADD; - type = ops[ops[node+1].ival].ival & 255; - str = walk(1,level,ops[node+1].ival,&numarg,prec+(type != OCONCAT)); - str_cat(str," . "); - type = ops[ops[node+2].ival].ival & 255; - str_scat(str, - fstr=walk(1,level,ops[node+2].ival,&numarg,prec+(type != OCONCAT))); - str_free(fstr); - break; - case OASSIGN: - prec = P_ASSIGN; - str = walk(0,level,ops[node+2].ival,&numarg,prec+1); - str_cat(str," "); - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - str_scat(str,tmpstr); - if (str_len(tmpstr) > 1) - numeric = 1; - str_free(tmpstr); - str_cat(str," "); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec)); - str_free(fstr); - numeric |= numarg; - if (strEQ(str->str_ptr,"$/ = ''")) - str_set(str, "$/ = \"\\n\\n\""); - break; - case OADD: - prec = P_ADD; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," + "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OSUBTRACT: - prec = P_ADD; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," - "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OMULT: - prec = P_MUL; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," * "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case ODIV: - prec = P_MUL; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," / "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OPOW: - prec = P_POW; - str = walk(1,level,ops[node+1].ival,&numarg,prec+1); - str_cat(str," ** "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec)); - str_free(fstr); - numeric = 1; - break; - case OMOD: - prec = P_MUL; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str," % "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OPOSTINCR: - prec = P_AUTO; - str = walk(1,level,ops[node+1].ival,&numarg,prec+1); - str_cat(str,"++"); - numeric = 1; - break; - case OPOSTDECR: - prec = P_AUTO; - str = walk(1,level,ops[node+1].ival,&numarg,prec+1); - str_cat(str,"--"); - numeric = 1; - break; - case OPREINCR: - prec = P_AUTO; - str = str_new(0); - str_set(str,"++"); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OPREDECR: - prec = P_AUTO; - str = str_new(0); - str_set(str,"--"); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,prec+1)); - str_free(fstr); - numeric = 1; - break; - case OUMINUS: - prec = P_UNARY; - str = str_new(0); - str_set(str,"-"); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,prec)); - str_free(fstr); - numeric = 1; - break; - case OUPLUS: - numeric = 1; - goto def; - case OPAREN: - str = str_new(0); - str_set(str,"("); - str_scat(str, - fstr=walk(useval != 0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,")"); - numeric |= numarg; - break; - case OGETLINE: - str = str_new(0); - if (useval) - str_cat(str,"("); - if (len > 0) { - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - if (!*fstr->str_ptr) { - str_cat(str,"$_"); - len = 2; /* a legal fiction */ - } - str_free(fstr); - } - else - str_cat(str,"$_"); - if (len > 1) { - tmpstr=walk(1,level,ops[node+3].ival,&numarg,P_MIN); - fstr=walk(1,level,ops[node+2].ival,&numarg,P_MIN); - if (!do_fancy_opens) { - t = tmpstr->str_ptr; - if (*t == '"' || *t == '\'') - t = cpytill(tokenbuf,t+1,*t); - else - fatal("Internal error: OGETLINE %s", t); - d = savestr(t); - s = savestr(tokenbuf); - for (t = tokenbuf; *t; t++) { - *t &= 127; - if (isLOWER(*t)) - *t = toUPPER(*t); - if (!isALPHANUMERIC(*t)) - *t = '_'; - } - if (!strchr(tokenbuf,'_')) - strcpy(t,"_FH"); - tmp3str = hfetch(symtab,tokenbuf); - if (!tmp3str) { - do_opens = TRUE; - str_cat(opens,"open("); - str_cat(opens,tokenbuf); - str_cat(opens,", "); - d[1] = '\0'; - str_cat(opens,d); - str_cat(opens,tmpstr->str_ptr+1); - opens->str_cur--; - if (*fstr->str_ptr == '|') - str_cat(opens,"|"); - str_cat(opens,d); - if (*fstr->str_ptr == '|') - str_cat(opens,") || die 'Cannot pipe from \""); - else - str_cat(opens,") || die 'Cannot open file \""); - if (*d == '"') - str_cat(opens,"'.\""); - str_cat(opens,s); - if (*d == '"') - str_cat(opens,"\".'"); - str_cat(opens,"\".';\n"); - hstore(symtab,tokenbuf,str_make("x")); - } - safefree(s); - safefree(d); - str_set(tmpstr,"'"); - str_cat(tmpstr,tokenbuf); - str_cat(tmpstr,"'"); - } - if (*fstr->str_ptr == '|') - str_cat(tmpstr,", '|'"); - str_free(fstr); - } - else - tmpstr = str_make(""); - sprintf(tokenbuf," = &Getline%d(%s)",len,tmpstr->str_ptr); - str_cat(str,tokenbuf); - str_free(tmpstr); - if (useval) - str_cat(str,",$getline_ok)"); - saw_getline |= 1 << len; - break; - case OSPRINTF: - str = str_new(0); - str_set(str,"sprintf("); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,")"); - break; - case OSUBSTR: - str = str_new(0); - str_set(str,"substr("); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_COMMA+1)); - str_free(fstr); - str_cat(str,", ("); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,P_COMMA+1)); - str_free(fstr); - str_cat(str,")-1"); - if (len == 3) { - str_cat(str,", "); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,P_COMMA+1)); - str_free(fstr); - } - str_cat(str,")"); - break; - case OSTRING: - str = str_new(0); - str_set(str,ops[node+1].cval); - break; - case OSPLIT: - str = str_new(0); - limit = ", -1)"; - numeric = 1; - tmpstr = walk(1,level,ops[node+2].ival,&numarg,P_MIN); - if (useval) - str_set(str,"(@"); - else - str_set(str,"@"); - str_scat(str,tmpstr); - str_cat(str," = split("); - if (len == 3) { - fstr = walk(1,level,ops[node+3].ival,&numarg,P_COMMA+1); - if (str_len(fstr) == 3 && *fstr->str_ptr == '\'') { - i = fstr->str_ptr[1] & 127; - if (strchr("*+?.[]()|^$\\",i)) - sprintf(tokenbuf,"/\\%c/",i); - else if (i == ' ') - sprintf(tokenbuf,"' '"); - else - sprintf(tokenbuf,"/%c/",i); - str_cat(str,tokenbuf); - } - else - str_scat(str,fstr); - str_free(fstr); - } - else if (const_FS) { - sprintf(tokenbuf,"/[%c\\n]/",const_FS); - str_cat(str,tokenbuf); - } - else if (saw_FS) - str_cat(str,"$FS"); - else { - str_cat(str,"' '"); - limit = ")"; - } - str_cat(str,", "); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_COMMA+1)); - str_free(fstr); - str_cat(str,limit); - if (useval) { - str_cat(str,")"); - } - str_free(tmpstr); - break; - case OINDEX: - str = str_new(0); - str_set(str,"(1+index("); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_COMMA+1)); - str_free(fstr); - str_cat(str,", "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,P_COMMA+1)); - str_free(fstr); - str_cat(str,"))"); - numeric = 1; - break; - case OMATCH: - str = str_new(0); - prec = P_ANDAND; - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MATCH+1)); - str_free(fstr); - str_cat(str," =~ "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,P_MATCH+1)); - str_free(fstr); - str_cat(str," ? scalar($RLENGTH = length($&), $RSTART = length($`)+1) : 0"); - numeric = 1; - break; - case OUSERDEF: - str = str_new(0); - subretnum = FALSE; - fstr=walk(1,level-1,ops[node+2].ival,&numarg,P_MIN); - curargs = str_new(0); - str_sset(curargs,fstr); - str_cat(curargs,","); - tmp2str=walk(1,level,ops[node+5].ival,&numarg,P_MIN); - str_free(curargs); - curargs = NULL; - level--; - subretnum |= numarg; - s = NULL; - t = tmp2str->str_ptr; - while ((t = instr(t,"return "))) - s = t++; - if (s) { - i = 0; - for (t = s+7; *t; t++) { - if (*t == ';' || *t == '}') - i++; - } - if (i == 1) { - strcpy(s,s+7); - tmp2str->str_cur -= 7; - } - } - str_set(str,"\n"); - tab(str,level); - str_cat(str,"sub "); - str_scat(str,tmpstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_cat(str," {\n"); - tab(str,++level); - if (fstr->str_cur) { - str_cat(str,"local("); - str_scat(str,fstr); - str_cat(str,") = @_;"); - } - str_free(fstr); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,P_MIN)); - str_free(fstr); - fixtab(str,level); - str_scat(str,fstr=walk(1,level,ops[node+4].ival,&numarg,P_MIN)); - str_free(fstr); - fixtab(str,level); - str_scat(str,tmp2str); - str_free(tmp2str); - fixtab(str,--level); - str_cat(str,"}\n"); - tab(str,level); - str_scat(subs,str); - str_set(str,""); - str_cat(tmpstr,"("); - tmp2str = str_new(0); - if (subretnum) - str_set(tmp2str,"1"); - hstore(symtab,tmpstr->str_ptr,tmp2str); - str_free(tmpstr); - level++; - break; - case ORETURN: - str = str_new(0); - if (len > 0) { - str_cat(str,"return "); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_UNI+1)); - str_free(fstr); - if (numarg) - subretnum = TRUE; - } - else - str_cat(str,"return"); - break; - case OUSERFUN: - str = str_new(0); - str_set(str,"&"); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,"("); - tmpstr = hfetch(symtab,str->str_ptr+3); - if (tmpstr && tmpstr->str_ptr) - numeric |= atoi(tmpstr->str_ptr); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,")"); - break; - case OGSUB: - case OSUB: { - int gsub = type == OGSUB ? 1 : 0; - str = str_new(0); - tmpstr = str_new(0); - i = 0; - if (len == 3) { - tmpstr = walk(1,level,ops[node+3].ival,&numarg,P_MATCH+1); - if (strNE(tmpstr->str_ptr,"$_")) { - str_cat(tmpstr, " =~ s"); - i++; - } - else - str_set(tmpstr, "s"); - } - else - str_set(tmpstr, "s"); - type = ops[ops[node+2].ival].ival; - len = type >> 8; - type &= 255; - tmp3str = str_new(0); - { - const char *s; - if (type == OSTR) { - tmp2str=walk(1,level,ops[ops[node+2].ival+1].ival,&numarg,P_MIN); - for (t = tmp2str->str_ptr, d=tokenbuf; *t; d++,t++) { - if (*t == '&') - *d++ = '$' + (char)128; - else if (*t == '$' || *t == '/') - *d++ = '\\' + (char)128; - *d = *t + 128; - } - *d = '\0'; - str_set(tmp2str,tokenbuf); - s = (gsub ? "/g" : "/"); - } - else { - tmp2str=walk(1,level,ops[node+2].ival,&numarg,P_MIN); - str_set(tmp3str,"($s_ = '\"'.("); - str_scat(tmp3str,tmp2str); - str_cat(tmp3str,").'\"') =~ s/&/\\$&/g, "); - str_set(tmp2str,"eval $s_"); - s = (gsub ? "/ge" : "/e"); - i++; - } - str_cat(tmp2str,s); - } - type = ops[ops[node+1].ival].ival; - len = type >> 8; - type &= 255; - fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN); - if (type == OREGEX) { - if (useval && i) - str_cat(str,"("); - str_scat(str,tmp3str); - str_scat(str,tmpstr); - str_scat(str,fstr); - str_scat(str,tmp2str); - } - else if ((type == OFLD && !split_to_array) || (type == OVAR && len == 1)) { - if (useval && i) - str_cat(str,"("); - str_scat(str,tmp3str); - str_scat(str,tmpstr); - str_cat(str,"/"); - str_scat(str,fstr); - str_cat(str,"/"); - str_scat(str,tmp2str); - } - else { - i++; - if (useval) - str_cat(str,"("); - str_cat(str,"$s = "); - str_scat(str,fstr); - str_cat(str,", "); - str_scat(str,tmp3str); - str_scat(str,tmpstr); - str_cat(str,"/$s/"); - str_scat(str,tmp2str); - } - if (useval && i) - str_cat(str,")"); - str_free(fstr); - str_free(tmpstr); - str_free(tmp2str); - str_free(tmp3str); - numeric = 1; - break; } - case ONUM: - str = walk(1,level,ops[node+1].ival,&numarg,P_MIN); - numeric = 1; - break; - case OSTR: - tmpstr = walk(1,level,ops[node+1].ival,&numarg,P_MIN); - { - const char *s = "'"; - for (t = tmpstr->str_ptr, d=tokenbuf; *t; d++,t++) { - if (*t == '\'') - s = "\""; - else if (*t == '\\') { - s = "\""; - *d++ = *t++ + 128; - switch (*t) { - case '\\': case '"': case 'n': case 't': case '$': - break; - default: /* hide this from perl */ - *d++ = '\\' + (char)128; - } - } - *d = *t + 128; - } - *d = '\0'; - str = str_new(0); - str_set(str,s); - str_cat(str,tokenbuf); - str_free(tmpstr); - str_cat(str,s); - } - break; - case ODEFINED: - prec = P_UNI; - str = str_new(0); - str_set(str,"defined $"); - goto addvar; - case ODELETE: - str = str_new(0); - str_set(str,"delete $"); - goto addvar; - case OSTAR: - str = str_new(0); - str_set(str,"*"); - goto addvar; - case OVAR: - str = str_new(0); - str_set(str,"$"); - addvar: - str_scat(str,tmpstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - if (len == 1) { - tmp2str = hfetch(symtab,tmpstr->str_ptr); - if (tmp2str && atoi(tmp2str->str_ptr)) - numeric = 2; - if (strEQ(str->str_ptr,"$FNR")) { - numeric = 1; - saw_FNR++; - str_set(str,"($.-$FNRbase)"); - } - else if (strEQ(str->str_ptr,"$NR")) { - numeric = 1; - str_set(str,"$."); - } - else if (strEQ(str->str_ptr,"$NF")) { - numeric = 1; - str_set(str,"($#Fld+1)"); - } - else if (strEQ(str->str_ptr,"$0")) - str_set(str,"$_"); - else if (strEQ(str->str_ptr,"$ARGC")) - str_set(str,"($#ARGV+2)"); - } - else { -#ifdef NOTDEF - if (curargs) { - sprintf(tokenbuf,"$%s,",tmpstr->str_ptr); - ??? if (instr(curargs->str_ptr,tokenbuf)) - str_cat(str,"\377"); /* can't translate yet */ - } -#endif - str_cat(tmpstr,"[]"); - tmp2str = hfetch(symtab,tmpstr->str_ptr); - if (tmp2str && atoi(tmp2str->str_ptr)) - str_cat(str,"[("); - else - str_cat(str,"{"); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - if (strEQ(str->str_ptr,"$ARGV[0")) { - str_set(str,"$ARGV0"); - saw_argv0++; - } - else { - if (tmp2str && atoi(tmp2str->str_ptr)) - strcpy(tokenbuf,")-1]"); - else - strcpy(tokenbuf,"}"); - *tokenbuf += (char)128; - str_cat(str,tokenbuf); - } - } - str_free(tmpstr); - break; - case OFLD: - str = str_new(0); - if (split_to_array) { - str_set(str,"$Fld"); - str_cat(str,"[("); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,")-1]"); - } - else { - i = atoi(walk(1,level,ops[node+1].ival,&numarg,P_MIN)->str_ptr); - if (i <= arymax) - sprintf(tokenbuf,"$%s",nameary[i]); - else - sprintf(tokenbuf,"$Fld%d",i); - str_set(str,tokenbuf); - } - break; - case OVFLD: - str = str_new(0); - str_set(str,"$Fld["); - i = ops[node+1].ival; - if ((ops[i].ival & 255) == OPAREN) - i = ops[i+1].ival; - tmpstr=walk(1,level,i,&numarg,P_MIN); - str_scat(str,tmpstr); - str_free(tmpstr); - str_cat(str,"]"); - break; - case OJUNK: - goto def; - case OSNEWLINE: - str = str_new(2); - str_set(str,";\n"); - tab(str,level); - break; - case ONEWLINE: - str = str_new(1); - str_set(str,"\n"); - tab(str,level); - break; - case OSCOMMENT: - str = str_new(0); - str_set(str,";"); - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - for (s = tmpstr->str_ptr; *s && *s != '\n'; s++) - *s += (char)128; - str_scat(str,tmpstr); - str_free(tmpstr); - tab(str,level); - break; - case OCOMMENT: - str = str_new(0); - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - for (s = tmpstr->str_ptr; *s && *s != '\n'; s++) - *s += (char)128; - str_scat(str,tmpstr); - str_free(tmpstr); - tab(str,level); - break; - case OCOMMA: - prec = P_COMMA; - str = walk(1,level,ops[node+1].ival,&numarg,prec); - str_cat(str,", "); - str_scat(str,fstr=walk(1,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,prec+1)); - str_free(fstr); - break; - case OSEMICOLON: - str = str_new(1); - str_set(str,";\n"); - tab(str,level); - break; - case OSTATES: - str = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - break; - case OSTATE: - str = str_new(0); - if (len >= 1) { - str_scat(str,fstr=walk(0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - if (len >= 2) { - tmpstr = walk(0,level,ops[node+2].ival,&numarg,P_MIN); - if (*tmpstr->str_ptr == ';') { - addsemi(str); - str_cat(str,tmpstr->str_ptr+1); - } - str_free(tmpstr); - } - } - break; - case OCLOSE: - str = str_make("close("); - tmpstr = walk(1,level,ops[node+1].ival,&numarg,P_MIN); - if (!do_fancy_opens) { - t = tmpstr->str_ptr; - if (*t == '"' || *t == '\'') - cpytill(tokenbuf,t+1,*t); - else - fatal("Internal error: OCLOSE %s",t); - s = savestr(tokenbuf); - for (t = tokenbuf; *t; t++) { - *t &= 127; - if (isLOWER(*t)) - *t = toUPPER(*t); - if (!isALPHANUMERIC(*t)) - *t = '_'; - } - if (!strchr(tokenbuf,'_')) - strcpy(t,"_FH"); - str_free(tmpstr); - safefree(s); - str_set(str,"close "); - str_cat(str,tokenbuf); - } - else { - sprintf(tokenbuf,"delete $opened{%s} && close(%s)", - tmpstr->str_ptr, tmpstr->str_ptr); - str_free(tmpstr); - str_set(str,tokenbuf); - } - break; - case OPRINTF: - case OPRINT: - lparen = ""; /* set to parens if necessary */ - rparen = ""; - str = str_new(0); - if (len == 3) { /* output redirection */ - tmpstr = walk(1,level,ops[node+3].ival,&numarg,P_MIN); - tmp2str = walk(1,level,ops[node+2].ival,&numarg,P_MIN); - if (!do_fancy_opens) { - t = tmpstr->str_ptr; - if (*t == '"' || *t == '\'') - t = cpytill(tokenbuf,t+1,*t); - else - fatal("Internal error: OPRINT"); - d = savestr(t); - s = savestr(tokenbuf); - for (t = tokenbuf; *t; t++) { - *t &= 127; - if (isLOWER(*t)) - *t = toUPPER(*t); - if (!isALPHANUMERIC(*t)) - *t = '_'; - } - if (!strchr(tokenbuf,'_')) - strcpy(t,"_FH"); - tmp3str = hfetch(symtab,tokenbuf); - if (!tmp3str) { - str_cat(opens,"open("); - str_cat(opens,tokenbuf); - str_cat(opens,", "); - d[1] = '\0'; - str_cat(opens,d); - str_scat(opens,tmp2str); - str_cat(opens,tmpstr->str_ptr+1); - if (*tmp2str->str_ptr == '|') - str_cat(opens,") || die 'Cannot pipe to \""); - else - str_cat(opens,") || die 'Cannot create file \""); - if (*d == '"') - str_cat(opens,"'.\""); - str_cat(opens,s); - if (*d == '"') - str_cat(opens,"\".'"); - str_cat(opens,"\".';\n"); - hstore(symtab,tokenbuf,str_make("x")); - } - str_free(tmpstr); - str_free(tmp2str); - safefree(s); - safefree(d); - } - else { - sprintf(tokenbuf,"&Pick('%s', %s) &&\n", - tmp2str->str_ptr, tmpstr->str_ptr); - str_cat(str,tokenbuf); - tab(str,level+1); - strcpy(tokenbuf,"$fh"); - str_free(tmpstr); - str_free(tmp2str); - lparen = "("; - rparen = ")"; - } - } - else - strcpy(tokenbuf,""); - str_cat(str,lparen); /* may be null */ - if (type == OPRINTF) - str_cat(str,"printf"); - else - str_cat(str,"print"); - saw_fh = 0; - if (len == 3 || do_fancy_opens) { - if (*tokenbuf) { - str_cat(str," "); - saw_fh = 1; - } - str_cat(str,tokenbuf); - } - tmpstr = walk(1+(type==OPRINT),level,ops[node+1].ival,&numarg,P_MIN); - if (!*tmpstr->str_ptr && lval_field) { - const char *t = (saw_OFS ? "$," : "' '"); - if (split_to_array) { - sprintf(tokenbuf,"join(%s,@Fld)",t); - str_cat(tmpstr,tokenbuf); - } - else { - for (i = 1; i < maxfld; i++) { - if (i <= arymax) - sprintf(tokenbuf,"$%s, ",nameary[i]); - else - sprintf(tokenbuf,"$Fld%d, ",i); - str_cat(tmpstr,tokenbuf); - } - if (maxfld <= arymax) - sprintf(tokenbuf,"$%s",nameary[maxfld]); - else - sprintf(tokenbuf,"$Fld%d",maxfld); - str_cat(tmpstr,tokenbuf); - } - } - if (*tmpstr->str_ptr) { - str_cat(str," "); - if (!saw_fh && *tmpstr->str_ptr == '(') { - str_cat(str,"("); - str_scat(str,tmpstr); - str_cat(str,")"); - } - else - str_scat(str,tmpstr); - } - else { - str_cat(str," $_"); - } - str_cat(str,rparen); /* may be null */ - str_free(tmpstr); - break; - case ORAND: - str = str_make("rand(1)"); - break; - case OSRAND: - str = str_make("srand("); - goto maybe0; - case OATAN2: - str = str_make("atan2("); - goto maybe0; - case OSIN: - str = str_make("sin("); - goto maybe0; - case OCOS: - str = str_make("cos("); - goto maybe0; - case OSYSTEM: - str = str_make("system("); - goto maybe0; - case OLENGTH: - str = str_make("length("); - goto maybe0; - case OLOG: - str = str_make("log("); - goto maybe0; - case OEXP: - str = str_make("exp("); - goto maybe0; - case OSQRT: - str = str_make("sqrt("); - goto maybe0; - case OINT: - str = str_make("int("); - maybe0: - numeric = 1; - if (len > 0) - tmpstr = walk(1,level,ops[node+1].ival,&numarg,P_MIN); - else - tmpstr = str_new(0); - if (!tmpstr->str_ptr || !*tmpstr->str_ptr) { - if (lval_field) { - const char *t = (saw_OFS ? "$," : "' '"); - if (split_to_array) { - sprintf(tokenbuf,"join(%s,@Fld)",t); - str_cat(tmpstr,tokenbuf); - } - else { - sprintf(tokenbuf,"join(%s, ",t); - str_cat(tmpstr,tokenbuf); - for (i = 1; i < maxfld; i++) { - if (i <= arymax) - sprintf(tokenbuf,"$%s,",nameary[i]); - else - sprintf(tokenbuf,"$Fld%d,",i); - str_cat(tmpstr,tokenbuf); - } - if (maxfld <= arymax) - sprintf(tokenbuf,"$%s)",nameary[maxfld]); - else - sprintf(tokenbuf,"$Fld%d)",maxfld); - str_cat(tmpstr,tokenbuf); - } - } - else - str_cat(tmpstr,"$_"); - } - if (strEQ(tmpstr->str_ptr,"$_")) { - if (type == OLENGTH && !do_chop) { - str = str_make("(length("); - str_cat(tmpstr,") - 1"); - } - } - str_scat(str,tmpstr); - str_free(tmpstr); - str_cat(str,")"); - break; - case OBREAK: - str = str_new(0); - str_set(str,"last"); - break; - case ONEXT: - str = str_new(0); - str_set(str,"next line"); - break; - case OEXIT: - str = str_new(0); - if (realexit) { - prec = P_UNI; - str_set(str,"exit"); - if (len == 1) { - str_cat(str," "); - exitval = TRUE; - str_scat(str, - fstr=walk(1,level,ops[node+1].ival,&numarg,prec+1)); - str_free(fstr); - } - } - else { - if (len == 1) { - str_set(str,"$ExitValue = "); - exitval = TRUE; - str_scat(str, - fstr=walk(1,level,ops[node+1].ival,&numarg,P_ASSIGN)); - str_free(fstr); - str_cat(str,"; "); - } - str_cat(str,"last line"); - } - break; - case OCONTINUE: - str = str_new(0); - str_set(str,"next"); - break; - case OREDIR: - goto def; - case OIF: - str = str_new(0); - str_set(str,"if ("); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,") "); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - if (len == 3) { - i = ops[node+3].ival; - if (i) { - if ((ops[i].ival & 255) == OBLOCK) { - i = ops[i+1].ival; - if (i) { - if ((ops[i].ival & 255) != OIF) - i = 0; - } - } - else - i = 0; - } - if (i) { - str_cat(str,"els"); - str_scat(str,fstr=walk(0,level,i,&numarg,P_MIN)); - str_free(fstr); - } - else { - str_cat(str,"else "); - str_scat(str,fstr=walk(0,level,ops[node+3].ival,&numarg,P_MIN)); - str_free(fstr); - } - } - break; - case OWHILE: - str = str_new(0); - str_set(str,"while ("); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,") "); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - break; - case ODO: - str = str_new(0); - str_set(str,"do "); - str_scat(str,fstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - if (str->str_ptr[str->str_cur - 1] == '\n') - --str->str_cur; - str_cat(str," while ("); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,");"); - break; - case OFOR: - str = str_new(0); - str_set(str,"for ("); - str_scat(str,tmpstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - i = numarg; - if (i) { - t = s = tmpstr->str_ptr; - while (isWORDCHAR(*t) || *t == '$') - t++; - i = t - s; - if (i < 2) - i = 0; - } - str_cat(str,"; "); - fstr=walk(1,level,ops[node+2].ival,&numarg,P_MIN); - if (i && (t = strchr(fstr->str_ptr,0377))) { - if (strnEQ(fstr->str_ptr,s,i)) - *t = ' '; - } - str_scat(str,fstr); - str_free(fstr); - str_free(tmpstr); - str_cat(str,"; "); - str_scat(str,fstr=walk(1,level,ops[node+3].ival,&numarg,P_MIN)); - str_free(fstr); - str_cat(str,") "); - str_scat(str,fstr=walk(0,level,ops[node+4].ival,&numarg,P_MIN)); - str_free(fstr); - break; - case OFORIN: - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - d = strchr(tmpstr->str_ptr,'$'); - if (!d) - fatal("Illegal for loop: %s",tmpstr->str_ptr); - s = strchr(d,'{'); - if (!s) - s = strchr(d,'['); - if (!s) - fatal("Illegal for loop: %s",d); - *s++ = '\0'; - for (t = s; (i = *t); t++) { - i &= 127; - if (i == '}' || i == ']') - break; - } - if (*t) - *t = '\0'; - str = str_new(0); - str_set(str,d+1); - str_cat(str,"[]"); - tmp2str = hfetch(symtab,str->str_ptr); - if (tmp2str && atoi(tmp2str->str_ptr)) { - sprintf(tokenbuf, - "foreach %s (0 .. $#%s) ", - s, - d+1); - } - else { - sprintf(tokenbuf, - "foreach %s (keys %%%s) ", - s, - d+1); - } - str_set(str,tokenbuf); - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - str_free(tmpstr); - break; - case OBLOCK: - str = str_new(0); - str_set(str,"{"); - if (len >= 2 && ops[node+2].ival) { - str_scat(str,fstr=walk(0,level,ops[node+2].ival,&numarg,P_MIN)); - str_free(fstr); - } - fixtab(str,++level); - str_scat(str,fstr=walk(0,level,ops[node+1].ival,&numarg,P_MIN)); - str_free(fstr); - addsemi(str); - fixtab(str,--level); - str_cat(str,"}\n"); - tab(str,level); - if (len >= 3) { - str_scat(str,fstr=walk(0,level,ops[node+3].ival,&numarg,P_MIN)); - str_free(fstr); - } - break; - default: - def: - if (len) { - if (len > 5) - fatal("Garbage length in walk"); - str = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - for (i = 2; i<= len; i++) { - str_scat(str,fstr=walk(0,level,ops[node+i].ival,&numarg,P_MIN)); - str_free(fstr); - } - } - else { - str = NULL; - } - break; - } - if (!str) - str = str_new(0); - - if (useval && prec < minprec) { /* need parens? */ - fstr = str_new(str->str_cur+2); - str_nset(fstr,"(",1); - str_scat(fstr,str); - str_ncat(fstr,")",1); - str_free(str); - str = fstr; - } - - *numericptr = numeric; -#ifdef DEBUGGING - if (debug & 4) { - printf("%3d %5d %15s %d %4d ",level,node,opname[type],len,str->str_cur); - for (t = str->str_ptr; *t && t - str->str_ptr < 40; t++) - if (*t == '\n') - printf("\\n"); - else if (*t == '\t') - printf("\\t"); - else - putchar(*t); - putchar('\n'); - } -#endif - return str; -} - -static void -tab(STR *str, int lvl) -{ - while (lvl > 1) { - str_cat(str,"\t"); - lvl -= 2; - } - if (lvl) - str_cat(str," "); -} - -static void -fixtab(STR *str, int lvl) -{ - char *s; - - /* strip trailing white space */ - - s = str->str_ptr+str->str_cur - 1; - while (s >= str->str_ptr && (*s == ' ' || *s == '\t' || *s == '\n')) - s--; - s[1] = '\0'; - str->str_cur = s + 1 - str->str_ptr; - if (s >= str->str_ptr && *s != '\n') - str_cat(str,"\n"); - - tab(str,lvl); -} - -static void -addsemi(STR *str) -{ - char *s; - - s = str->str_ptr+str->str_cur - 1; - while (s >= str->str_ptr && (*s == ' ' || *s == '\t' || *s == '\n')) - s--; - if (s >= str->str_ptr && *s != ';' && *s != '}') - str_cat(str,";"); -} - -static void -emit_split(STR *str, int level) -{ - int i; - - if (split_to_array) - str_cat(str,"@Fld"); - else { - str_cat(str,"("); - for (i = 1; i < maxfld; i++) { - if (i <= arymax) - sprintf(tokenbuf,"$%s,",nameary[i]); - else - sprintf(tokenbuf,"$Fld%d,",i); - str_cat(str,tokenbuf); - } - if (maxfld <= arymax) - sprintf(tokenbuf,"$%s)",nameary[maxfld]); - else - sprintf(tokenbuf,"$Fld%d)",maxfld); - str_cat(str,tokenbuf); - } - if (const_FS) { - sprintf(tokenbuf," = split(/[%c\\n]/, $_, -1);\n",const_FS); - str_cat(str,tokenbuf); - } - else if (saw_FS) - str_cat(str," = split($FS, $_, -1);\n"); - else - str_cat(str," = split(' ', $_, -1);\n"); - tab(str,level); -} - -int -prewalk(int numit, int level, int node, int *numericptr) -{ - int len; - int type; - int i; - int numarg; - int numeric = FALSE; - STR *tmpstr; - STR *tmp2str; - - if (!node) { - *numericptr = 0; - return 0; - } - type = ops[node].ival; - len = type >> 8; - type &= 255; - switch (type) { - case OPROG: - prewalk(0,level,ops[node+1].ival,&numarg); - if (ops[node+2].ival) { - prewalk(0,level,ops[node+2].ival,&numarg); - } - ++level; - prewalk(0,level,ops[node+3].ival,&numarg); - --level; - if (ops[node+3].ival) { - prewalk(0,level,ops[node+4].ival,&numarg); - } - break; - case OHUNKS: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - if (len == 3) { - prewalk(0,level,ops[node+3].ival,&numarg); - } - break; - case ORANGE: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - break; - case OPAT: - goto def; - case OREGEX: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OHUNK: - if (len == 1) { - prewalk(0,level,ops[node+1].ival,&numarg); - } - else { - i = prewalk(0,level,ops[node+1].ival,&numarg); - if (i) { - ++level; - prewalk(0,level,ops[node+2].ival,&numarg); - --level; - } - else { - prewalk(0,level,ops[node+2].ival,&numarg); - } - } - break; - case OPPAREN: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OPANDAND: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OPOROR: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OPNOT: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OCPAREN: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric |= numarg; - break; - case OCANDAND: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric = 1; - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OCOROR: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric = 1; - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OCNOT: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case ORELOP: - prewalk(0,level,ops[node+2].ival,&numarg); - numeric |= numarg; - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+3].ival,&numarg); - numeric |= numarg; - numeric = 1; - break; - case ORPAREN: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric |= numarg; - break; - case OMATCHOP: - prewalk(0,level,ops[node+2].ival,&numarg); - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+3].ival,&numarg); - numeric = 1; - break; - case OMPAREN: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric |= numarg; - break; - case OCONCAT: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OASSIGN: - prewalk(0,level,ops[node+2].ival,&numarg); - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+3].ival,&numarg); - if (numarg || strlen(ops[ops[node+1].ival+1].cval) > (Size_t)1) { - numericize(ops[node+2].ival); - if (!numarg) - numericize(ops[node+3].ival); - } - numeric |= numarg; - break; - case OADD: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OSUBTRACT: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OMULT: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case ODIV: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OPOW: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OMOD: - prewalk(1,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OPOSTINCR: - prewalk(1,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OPOSTDECR: - prewalk(1,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OPREINCR: - prewalk(1,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OPREDECR: - prewalk(1,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OUMINUS: - prewalk(1,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OUPLUS: - prewalk(1,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OPAREN: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric |= numarg; - break; - case OGETLINE: - break; - case OSPRINTF: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OSUBSTR: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(1,level,ops[node+2].ival,&numarg); - if (len == 3) { - prewalk(1,level,ops[node+3].ival,&numarg); - } - break; - case OSTRING: - break; - case OSPLIT: - numeric = 1; - prewalk(0,level,ops[node+2].ival,&numarg); - if (len == 3) - prewalk(0,level,ops[node+3].ival,&numarg); - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OINDEX: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OMATCH: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - numeric = 1; - break; - case OUSERDEF: - subretnum = FALSE; - --level; - tmpstr = walk(0,level,ops[node+1].ival,&numarg,P_MIN); - ++level; - prewalk(0,level,ops[node+2].ival,&numarg); - prewalk(0,level,ops[node+4].ival,&numarg); - prewalk(0,level,ops[node+5].ival,&numarg); - --level; - str_cat(tmpstr,"("); - tmp2str = str_new(0); - if (subretnum || numarg) - str_set(tmp2str,"1"); - hstore(symtab,tmpstr->str_ptr,tmp2str); - str_free(tmpstr); - level++; - break; - case ORETURN: - if (len > 0) { - prewalk(0,level,ops[node+1].ival,&numarg); - if (numarg) - subretnum = TRUE; - } - break; - case OUSERFUN: - tmp2str = str_new(0); - str_scat(tmp2str,tmpstr=walk(1,level,ops[node+1].ival,&numarg,P_MIN)); - fixrargs(tmpstr->str_ptr,ops[node+2].ival,0); - str_free(tmpstr); - str_cat(tmp2str,"("); - tmpstr = hfetch(symtab,tmp2str->str_ptr); - if (tmpstr && tmpstr->str_ptr) - numeric |= atoi(tmpstr->str_ptr); - prewalk(0,level,ops[node+2].ival,&numarg); - str_free(tmp2str); - break; - case OGSUB: - case OSUB: - if (len >= 3) - prewalk(0,level,ops[node+3].ival,&numarg); - prewalk(0,level,ops[ops[node+2].ival+1].ival,&numarg); - prewalk(0,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case ONUM: - prewalk(0,level,ops[node+1].ival,&numarg); - numeric = 1; - break; - case OSTR: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case ODEFINED: - case ODELETE: - case OSTAR: - case OVAR: - prewalk(0,level,ops[node+1].ival,&numarg); - if (len == 1) { - if (numit) - numericize(node); - } - else { - prewalk(0,level,ops[node+2].ival,&numarg); - } - break; - case OFLD: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OVFLD: - i = ops[node+1].ival; - prewalk(0,level,i,&numarg); - break; - case OJUNK: - goto def; - case OSNEWLINE: - break; - case ONEWLINE: - break; - case OSCOMMENT: - break; - case OCOMMENT: - break; - case OCOMMA: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - prewalk(0,level,ops[node+3].ival,&numarg); - break; - case OSEMICOLON: - break; - case OSTATES: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OSTATE: - if (len >= 1) { - prewalk(0,level,ops[node+1].ival,&numarg); - if (len >= 2) { - prewalk(0,level,ops[node+2].ival,&numarg); - } - } - break; - case OCLOSE: - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OPRINTF: - case OPRINT: - if (len == 3) { /* output redirection */ - prewalk(0,level,ops[node+3].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - } - prewalk(0+(type==OPRINT),level,ops[node+1].ival,&numarg); - break; - case ORAND: - break; - case OSRAND: - goto maybe0; - case OATAN2: - goto maybe0; - case OSIN: - goto maybe0; - case OCOS: - goto maybe0; - case OSYSTEM: - goto maybe0; - case OLENGTH: - goto maybe0; - case OLOG: - goto maybe0; - case OEXP: - goto maybe0; - case OSQRT: - goto maybe0; - case OINT: - maybe0: - numeric = 1; - if (len > 0) - prewalk(type != OLENGTH && type != OSYSTEM, - level,ops[node+1].ival,&numarg); - break; - case OBREAK: - break; - case ONEXT: - break; - case OEXIT: - if (len == 1) { - prewalk(1,level,ops[node+1].ival,&numarg); - } - break; - case OCONTINUE: - break; - case OREDIR: - goto def; - case OIF: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - if (len == 3) { - prewalk(0,level,ops[node+3].ival,&numarg); - } - break; - case OWHILE: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - break; - case OFOR: - prewalk(0,level,ops[node+1].ival,&numarg); - prewalk(0,level,ops[node+2].ival,&numarg); - prewalk(0,level,ops[node+3].ival,&numarg); - prewalk(0,level,ops[node+4].ival,&numarg); - break; - case OFORIN: - prewalk(0,level,ops[node+2].ival,&numarg); - prewalk(0,level,ops[node+1].ival,&numarg); - break; - case OBLOCK: - if (len == 2) { - prewalk(0,level,ops[node+2].ival,&numarg); - } - ++level; - prewalk(0,level,ops[node+1].ival,&numarg); - --level; - break; - default: - def: - if (len) { - if (len > 5) - fatal("Garbage length in prewalk"); - prewalk(0,level,ops[node+1].ival,&numarg); - for (i = 2; i<= len; i++) { - prewalk(0,level,ops[node+i].ival,&numarg); - } - } - break; - } - *numericptr = numeric; - return 1; -} - -static void -numericize(int node) -{ - int len; - int type; - STR *tmpstr; - STR *tmp2str; - int numarg; - - type = ops[node].ival; - len = type >> 8; - type &= 255; - if (type == OVAR && len == 1) { - tmpstr=walk(0,0,ops[node+1].ival,&numarg,P_MIN); - tmp2str = str_make("1"); - hstore(symtab,tmpstr->str_ptr,tmp2str); - } -} |