diff options
author | peter <peter@FreeBSD.org> | 1995-12-30 19:02:48 +0000 |
---|---|---|
committer | peter <peter@FreeBSD.org> | 1995-12-30 19:02:48 +0000 |
commit | c3f352d4ad515968c54d216a0e53252eff8ab3ef (patch) | |
tree | 48ddeda3c6c8d8572cc34bf52ccf9cb9bd97d488 /usr.bin/f2c | |
parent | ab124e78b0271ddb904b761b31e5c9a0cf24e070 (diff) | |
download | FreeBSD-src-c3f352d4ad515968c54d216a0e53252eff8ab3ef.zip FreeBSD-src-c3f352d4ad515968c54d216a0e53252eff8ab3ef.tar.gz |
This commit was generated by cvs2svn to compensate for changes in r13122,
which included commits to RCS files with non-trunk default branches.
Diffstat (limited to 'usr.bin/f2c')
-rw-r--r-- | usr.bin/f2c/dependencies | 60 | ||||
-rw-r--r-- | usr.bin/f2c/f2c.1t | 336 | ||||
-rw-r--r-- | usr.bin/f2c/gram.c | 1829 | ||||
-rw-r--r-- | usr.bin/f2c/makefile | 90 | ||||
-rw-r--r-- | usr.bin/f2c/xsum0.out | 56 |
5 files changed, 0 insertions, 2371 deletions
diff --git a/usr.bin/f2c/dependencies b/usr.bin/f2c/dependencies deleted file mode 100644 index 9937e0b..0000000 --- a/usr.bin/f2c/dependencies +++ /dev/null @@ -1,60 +0,0 @@ -f2c/src* -Notice= -notice -README= -readme -cds.c= -data.c= -defines.h= -defs.h= -equiv.c= -error.c= -exec.c= -expr.c= -f2c.1= -f2c.1t= -f2c.h= -format.c= -format.h= -formatdata.c= -ftypes.h= -gram.dcl= -gram.exec= -gram.expr= -gram.head= -gram.io= -init.c= -intr.c= -io.c= -iob.h= -lex.c= -machdefs.h= -main.c= -makefile= -malloc.c= -mem.c= -memset.c= -misc.c= -names.c= -names.h= -niceprintf.c= -niceprintf.h= -output.c= -output.h= -p1defs.h= -p1output.c= -parse.h= -parse_args.c= -pccdefs.h= -pread.c= -proc.c= -put.c= -putpcc.c= -sysdep.c= -sysdep.h= -tokens= -usignal.h= -vax.c= -version.c= -xsum.c= -xsum0.out= diff --git a/usr.bin/f2c/f2c.1t b/usr.bin/f2c/f2c.1t deleted file mode 100644 index 2a59dff..0000000 --- a/usr.bin/f2c/f2c.1t +++ /dev/null @@ -1,336 +0,0 @@ -. \" Definitions of F, L and LR for the benefit of systems -. \" whose -man lacks them... -.de F -.nh -.if n \%\&\\$1 -.if t \%\&\f(CW\\$1\fR -.hy 14 -.. -.de L -.nh -.if n \%`\\$1' -.if t \%\&\f(CW\\$1\fR -.hy 14 -.. -.de LR -.nh -.if n \%`\\$1'\\$2 -.if t \%\&\f(CW\\$1\fR\\$2 -.hy 14 -.. -.TH F2C 1 -.CT 1 prog_other -.SH NAME -f\^2c \(mi Convert Fortran 77 to C or C++ -.SH SYNOPSIS -.B f\^2c -[ -.I option ... -] -.I file ... -.SH DESCRIPTION -.I F2c -converts Fortran 77 source code in -.I files -with names ending in -.L .f -or -.L .F -to C (or C++) source files in the -current directory, with -.L .c -substituted -for the final -.L .f -or -.LR .F . -If no Fortran files are named, -.I f\^2c -reads Fortran from standard input and -writes C on standard output. -.I File -names that end with -.L .p -or -.L .P -are taken to be prototype -files, as produced by option -.LR -P , -and are read first. -.PP -The following options have the same meaning as in -.IR f\^77 (1). -.TP -.B -C -Compile code to check that subscripts are within declared array bounds. -.TP -.B -I2 -Render INTEGER and LOGICAL as short, -INTEGER\(**4 as long int. Assume the default \fIlibF77\fR -and \fIlibI77\fR: allow only INTEGER\(**4 (and no LOGICAL) -variables in INQUIREs. Option -.L -I4 -confirms the default rendering of INTEGER as long int. -.TP -.B -onetrip -Compile DO loops that are performed at least once if reached. -(Fortran 77 DO loops are not performed at all if the upper limit is smaller than the lower limit.) -.TP -.B -U -Honor the case of variable and external names. Fortran keywords must be in -.I -lower -case. -.TP -.B -u -Make the default type of a variable `undefined' rather than using the default Fortran rules. -.TP -.B -w -Suppress all warning messages. -If the option is -.LR -w66 , -only Fortran 66 compatibility warnings are suppressed. -.PP -The following options are peculiar to -.IR f\^2c . -.TP -.B -A -Produce -.SM ANSI -C. -Default is old-style C. -.TP -.B -a -Make local variables automatic rather than static -unless they appear in a -.SM "DATA, EQUIVALENCE, NAMELIST," -or -.SM SAVE -statement. -.TP -.B -C++ -Output C++ code. -.TP -.B -c -Include original Fortran source as comments. -.TP -.B -E -Declare uninitialized -.SM COMMON -to be -.B Extern -(overridably defined in -.F f2c.h -as -.B extern). -.TP -.B -ec -Place uninitialized -.SM COMMON -blocks in separate files: -.B COMMON /ABC/ -appears in file -.BR abc_com.c . -Option -.LR -e1c -bundles the separate files -into the output file, with comments that give an unbundling -.IR sed (1) -script. -.TP -.B -ext -Complain about -.IR f\^77 (1) -extensions. -.TP -.B -f -Assume free-format input: accept text after column 72 and do not -pad fixed-format lines shorter than 72 characters with blanks. -.TP -.B -72 -Treat text appearing after column 72 as an error. -.TP -.B -g -Include original Fortran line numbers in \f(CW#line\fR lines. -.TP -.B -h -Emulate Fortran 66's treatment of Hollerith: try to align character strings on -word (or, if the option is -.LR -hd , -on double-word) boundaries. -.TP -.B -i2 -Similar to -.BR -I2 , -but assume a modified -.I libF77 -and -.I libI77 -(compiled with -.BR -Df\^2c_i2 ), -so -.SM INTEGER -and -.SM LOGICAL -variables may be assigned by -.SM INQUIRE -and array lengths are stored in short ints. -.TP -.B -kr -Use temporary values to enforce Fortran expression evaluation -where K&R (first edition) parenthesization rules allow rearrangement. -If the option is -.LR -krd , -use double precision temporaries even for single-precision operands. -.TP -.B -P -Write a -.IB file .P -of ANSI (or C++) prototypes -for definitions in each input -.IB file .f -or -.IB file .F . -When reading Fortran from standard input, write prototypes -at the beginning of standard output. Option -.B -Ps -implies -.B -P -and gives exit status 4 if rerunning -.I f\^2c -may change prototypes or declarations. -.TP -.B -p -Supply preprocessor definitions to make common-block members -look like local variables. -.TP -.B -R -Do not promote -.SM REAL -functions and operations to -.SM DOUBLE PRECISION. -Option -.L -!R -confirms the default, which imitates -.IR f\^77 . -.TP -.B -r -Cast values of REAL functions (including intrinsics) to REAL. -.TP -.B -r8 -Promote -.SM REAL -to -.SM DOUBLE PRECISION, COMPLEX -to -.SM DOUBLE COMPLEX. -.TP -.B -s -Preserve multidimensional subscripts. -.TP -.BI -T dir -Put temporary files in directory -.I dir. -.TP -.B -w8 -Suppress warnings when -.SM COMMON -or -.SM EQUIVALENCE -forces odd-word alignment of doubles. -.TP -.BI -W n -Assume -.I n -characters/word (default 4) -when initializing numeric variables with character data. -.TP -.B -z -Do not implicitly recognize -.SM DOUBLE COMPLEX. -.TP -.B -!bs -Do not recognize \fIb\fRack\fIs\fRlash escapes -(\e", \e', \e0, \e\e, \eb, \ef, \en, \er, \et, \ev) in character strings. -.TP -.B -!c -Inhibit C output, but produce -.B -P -output. -.TP -.B -!I -Reject -.B include -statements. -.TP -.B -!i8 -Disallow -.SM INTEGER*8. -.TP -.B -!it -Don't infer types of untyped -.SM EXTERNAL -procedures from use as parameters to previously defined or prototyped -procedures. -.TP -.B -!P -Do not attempt to infer -.SM ANSI -or C++ -prototypes from usage. -.PP -The resulting C invokes the support routines of -.IR f\^77 ; -object code should be loaded by -.I f\^77 -or with -.IR ld (1) -or -.IR cc (1) -options -.BR "-lF77 -lI77 -lm" . -Calling conventions -are those of -.IR f\&77 : -see the reference below. -.br -.SH FILES -.TP -.IB file .[fF] -input file -.TP -.B *.c -output file -.TP -.F /usr/include/f2c.h -header file -.TP -.F /usr/lib/libF77.a -intrinsic function library -.TP -.F /usr/lib/libI77.a -Fortran I/O library -.TP -.F /lib/libc.a -C library, see section 3 -.SH "SEE ALSO" -S. I. Feldman and -P. J. Weinberger, -`A Portable Fortran 77 Compiler', -\fIUNIX Time Sharing System Programmer's Manual\fR, -Tenth Edition, Volume 2, AT&T Bell Laboratories, 1990. -.SH DIAGNOSTICS -The diagnostics produced by -.I f\^2c -are intended to be -self-explanatory. -.SH BUGS -Floating-point constant expressions are simplified in -the floating-point arithmetic of the machine running -.IR f\^2c , -so they are typically accurate to at most 16 or 17 decimal places. -.br -Untypable -.SM EXTERNAL -functions are declared -.BR int . diff --git a/usr.bin/f2c/gram.c b/usr.bin/f2c/gram.c deleted file mode 100644 index 99ac190e..0000000 --- a/usr.bin/f2c/gram.c +++ /dev/null @@ -1,1829 +0,0 @@ -# define SEOS 1 -# define SCOMMENT 2 -# define SLABEL 3 -# define SUNKNOWN 4 -# define SHOLLERITH 5 -# define SICON 6 -# define SRCON 7 -# define SDCON 8 -# define SBITCON 9 -# define SOCTCON 10 -# define SHEXCON 11 -# define STRUE 12 -# define SFALSE 13 -# define SNAME 14 -# define SNAMEEQ 15 -# define SFIELD 16 -# define SSCALE 17 -# define SINCLUDE 18 -# define SLET 19 -# define SASSIGN 20 -# define SAUTOMATIC 21 -# define SBACKSPACE 22 -# define SBLOCK 23 -# define SCALL 24 -# define SCHARACTER 25 -# define SCLOSE 26 -# define SCOMMON 27 -# define SCOMPLEX 28 -# define SCONTINUE 29 -# define SDATA 30 -# define SDCOMPLEX 31 -# define SDIMENSION 32 -# define SDO 33 -# define SDOUBLE 34 -# define SELSE 35 -# define SELSEIF 36 -# define SEND 37 -# define SENDFILE 38 -# define SENDIF 39 -# define SENTRY 40 -# define SEQUIV 41 -# define SEXTERNAL 42 -# define SFORMAT 43 -# define SFUNCTION 44 -# define SGOTO 45 -# define SASGOTO 46 -# define SCOMPGOTO 47 -# define SARITHIF 48 -# define SLOGIF 49 -# define SIMPLICIT 50 -# define SINQUIRE 51 -# define SINTEGER 52 -# define SINTRINSIC 53 -# define SLOGICAL 54 -# define SNAMELIST 55 -# define SOPEN 56 -# define SPARAM 57 -# define SPAUSE 58 -# define SPRINT 59 -# define SPROGRAM 60 -# define SPUNCH 61 -# define SREAD 62 -# define SREAL 63 -# define SRETURN 64 -# define SREWIND 65 -# define SSAVE 66 -# define SSTATIC 67 -# define SSTOP 68 -# define SSUBROUTINE 69 -# define STHEN 70 -# define STO 71 -# define SUNDEFINED 72 -# define SWRITE 73 -# define SLPAR 74 -# define SRPAR 75 -# define SEQUALS 76 -# define SCOLON 77 -# define SCOMMA 78 -# define SCURRENCY 79 -# define SPLUS 80 -# define SMINUS 81 -# define SSTAR 82 -# define SSLASH 83 -# define SPOWER 84 -# define SCONCAT 85 -# define SAND 86 -# define SOR 87 -# define SNEQV 88 -# define SEQV 89 -# define SNOT 90 -# define SEQ 91 -# define SLT 92 -# define SGT 93 -# define SLE 94 -# define SGE 95 -# define SNE 96 -# define SENDDO 97 -# define SWHILE 98 -# define SSLASHD 99 - -/* # line 124 "gram.in" */ -#include "defs.h" -#include "p1defs.h" - -static int nstars; /* Number of labels in an - alternate return CALL */ -static int datagripe; -static int ndim; -static int vartype; -int new_dcl; -static ftnint varleng; -static struct Dims dims[MAXDIM+1]; -extern struct Labelblock **labarray; /* Labels in an alternate - return CALL */ -extern int maxlablist; - -/* The next two variables are used to verify that each statement might be reached - during runtime. lastwasbranch is tested only in the defintion of the - stat: nonterminal. */ - -int lastwasbranch = NO; -static int thiswasbranch = NO; -extern ftnint yystno; -extern flag intonly; -static chainp datastack; -extern long laststfcn, thisstno; -extern int can_include; /* for netlib */ - -ftnint convci(); -Addrp nextdata(); -expptr mklogcon(), mkaddcon(), mkrealcon(), mkstrcon(), mkbitcon(); -expptr mkcxcon(); -struct Listblock *mklist(); -struct Listblock *mklist(); -struct Impldoblock *mkiodo(); -Extsym *comblock(); -#define ESNULL (Extsym *)0 -#define NPNULL (Namep)0 -#define LBNULL (struct Listblock *)0 -extern void freetemps(), make_param(); - - static void -pop_datastack() { - chainp d0 = datastack; - if (d0->datap) - curdtp = (chainp)d0->datap; - datastack = d0->nextp; - d0->nextp = 0; - frchain(&d0); - } - - -/* # line 178 "gram.in" */ -typedef union { - int ival; - ftnint lval; - char *charpval; - chainp chval; - tagptr tagval; - expptr expval; - struct Labelblock *labval; - struct Nameblock *namval; - struct Eqvchain *eqvval; - Extsym *extval; - } YYSTYPE; -#define yyclearin yychar = -1 -#define yyerrok yyerrflag = 0 -extern int yychar; -typedef int yytabelem; -extern yytabelem yyerrflag; -#ifndef YYMAXDEPTH -#define YYMAXDEPTH 150 -#endif -YYSTYPE yylval, yyval; -# define YYERRCODE 256 -yytabelem yyexca[] ={ --1, 1, - 0, -1, - -2, 0, --1, 20, - 1, 38, - -2, 228, --1, 24, - 1, 42, - -2, 228, --1, 122, - 6, 240, - -2, 228, --1, 150, - 1, 244, - -2, 188, --1, 174, - 1, 265, - 78, 265, - -2, 188, --1, 223, - 77, 173, - -2, 139, --1, 245, - 74, 228, - -2, 225, --1, 271, - 1, 286, - -2, 143, --1, 275, - 1, 295, - 78, 295, - -2, 145, --1, 328, - 77, 174, - -2, 141, --1, 358, - 1, 267, - 14, 267, - 74, 267, - 78, 267, - -2, 189, --1, 436, - 91, 0, - 92, 0, - 93, 0, - 94, 0, - 95, 0, - 96, 0, - -2, 153, --1, 453, - 1, 289, - 78, 289, - -2, 143, --1, 455, - 1, 291, - 78, 291, - -2, 143, --1, 457, - 1, 293, - 78, 293, - -2, 143, --1, 459, - 1, 296, - 78, 296, - -2, 144, --1, 504, - 78, 289, - -2, 143, - }; -# define YYNPROD 301 -# define YYLAST 1346 -yytabelem yyact[]={ - - 237, 274, 471, 317, 316, 412, 420, 297, 470, 399, - 413, 397, 386, 357, 398, 266, 128, 356, 273, 252, - 292, 5, 116, 295, 326, 303, 222, 99, 184, 121, - 195, 229, 17, 203, 270, 304, 313, 199, 201, 118, - 94, 202, 396, 104, 210, 183, 236, 101, 106, 234, - 264, 103, 111, 336, 260, 95, 96, 97, 165, 166, - 334, 335, 336, 395, 105, 311, 309, 190, 130, 131, - 132, 133, 120, 135, 119, 114, 157, 129, 157, 475, - 103, 272, 334, 335, 336, 396, 521, 103, 278, 483, - 535, 165, 166, 334, 335, 336, 342, 341, 340, 339, - 338, 137, 343, 345, 344, 347, 346, 348, 450, 258, - 259, 260, 539, 165, 166, 258, 259, 260, 261, 525, - 102, 522, 155, 409, 155, 186, 187, 103, 408, 117, - 165, 166, 258, 259, 260, 318, 100, 527, 484, 188, - 446, 185, 480, 230, 240, 240, 194, 193, 290, 120, - 211, 119, 462, 481, 157, 294, 482, 257, 157, 243, - 468, 214, 463, 469, 461, 464, 460, 239, 241, 220, - 215, 218, 157, 219, 213, 165, 166, 334, 335, 336, - 342, 341, 340, 157, 371, 452, 343, 345, 344, 347, - 346, 348, 443, 428, 377, 294, 102, 102, 102, 102, - 155, 189, 447, 149, 155, 446, 192, 103, 98, 196, - 197, 198, 277, 376, 320, 321, 206, 288, 155, 289, - 300, 375, 299, 324, 315, 328, 275, 275, 330, 155, - 310, 333, 196, 216, 217, 350, 269, 207, 308, 352, - 353, 333, 100, 177, 354, 349, 323, 112, 245, 257, - 247, 110, 157, 417, 286, 287, 418, 362, 157, 157, - 157, 157, 157, 257, 257, 109, 108, 268, 279, 280, - 281, 265, 107, 355, 4, 333, 427, 465, 378, 370, - 170, 172, 176, 257, 165, 166, 258, 259, 260, 261, - 102, 406, 232, 293, 407, 381, 422, 390, 155, 400, - 391, 223, 419, 422, 155, 155, 155, 155, 155, 117, - 221, 314, 392, 319, 387, 359, 372, 196, 360, 373, - 374, 333, 333, 536, 350, 333, 275, 250, 424, 333, - 405, 333, 410, 532, 230, 432, 433, 434, 435, 436, - 437, 438, 439, 440, 441, 403, 331, 156, 401, 332, - 531, 333, 530, 333, 333, 333, 388, 526, 380, 529, - 524, 157, 257, 333, 431, 492, 257, 257, 257, 257, - 257, 382, 383, 235, 426, 384, 358, 494, 296, 333, - 448, 165, 166, 258, 259, 260, 261, 451, 165, 166, - 258, 259, 260, 261, 103, 445, 472, 400, 421, 191, - 402, 196, 103, 150, 307, 174, 285, 155, 474, 246, - 476, 416, 467, 466, 242, 226, 223, 200, 212, 136, - 209, 486, 171, 488, 490, 275, 275, 275, 141, 240, - 496, 429, 329, 333, 333, 333, 333, 333, 333, 333, - 333, 333, 333, 403, 497, 479, 401, 403, 487, 154, - 257, 154, 495, 493, 306, 485, 502, 454, 456, 458, - 500, 491, 268, 499, 505, 506, 507, 103, 451, 271, - 271, 472, 30, 333, 414, 501, 400, 508, 511, 509, - 387, 244, 208, 510, 516, 514, 515, 333, 517, 333, - 513, 333, 520, 293, 518, 225, 240, 333, 402, 523, - 92, 248, 402, 528, 6, 262, 123, 249, 81, 80, - 275, 275, 275, 79, 534, 533, 479, 78, 173, 263, - 314, 77, 403, 76, 537, 401, 351, 154, 75, 333, - 282, 154, 60, 49, 48, 333, 45, 33, 333, 538, - 113, 205, 454, 456, 458, 154, 267, 165, 166, 334, - 335, 336, 342, 540, 503, 411, 154, 204, 394, 393, - 298, 478, 503, 503, 503, 134, 389, 312, 115, 379, - 26, 25, 24, 23, 302, 22, 305, 402, 21, 385, - 284, 9, 503, 8, 7, 2, 519, 301, 20, 319, - 164, 51, 489, 291, 228, 327, 325, 415, 91, 361, - 255, 53, 337, 19, 55, 365, 366, 367, 368, 369, - 37, 224, 3, 1, 0, 351, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 154, 0, 0, 0, 0, - 0, 154, 154, 154, 154, 154, 0, 0, 0, 267, - 0, 512, 267, 267, 165, 166, 334, 335, 336, 342, - 341, 340, 339, 338, 0, 343, 345, 344, 347, 346, - 348, 165, 166, 334, 335, 336, 342, 341, 453, 455, - 457, 0, 343, 345, 344, 347, 346, 348, 0, 0, - 305, 0, 459, 0, 0, 0, 0, 165, 166, 334, - 335, 336, 342, 341, 340, 339, 338, 351, 343, 345, - 344, 347, 346, 348, 444, 0, 0, 0, 449, 165, - 166, 334, 335, 336, 342, 341, 340, 339, 338, 0, - 343, 345, 344, 347, 346, 348, 165, 166, 334, 335, - 336, 342, 0, 0, 154, 0, 498, 343, 345, 344, - 347, 346, 348, 0, 0, 267, 0, 0, 0, 0, - 0, 442, 0, 504, 455, 457, 165, 166, 334, 335, - 336, 342, 341, 340, 339, 338, 0, 343, 345, 344, - 347, 346, 348, 0, 0, 0, 0, 0, 0, 430, - 0, 477, 0, 305, 165, 166, 334, 335, 336, 342, - 341, 340, 339, 338, 0, 343, 345, 344, 347, 346, - 348, 423, 0, 0, 0, 0, 165, 166, 334, 335, - 336, 342, 341, 340, 339, 338, 0, 343, 345, 344, - 347, 346, 348, 0, 0, 0, 267, 0, 0, 0, - 0, 165, 166, 334, 335, 336, 342, 341, 340, 339, - 338, 12, 343, 345, 344, 347, 346, 348, 0, 0, - 0, 0, 0, 0, 305, 10, 56, 46, 73, 85, - 14, 61, 70, 90, 38, 66, 47, 42, 68, 72, - 31, 67, 35, 34, 11, 87, 36, 18, 41, 39, - 28, 16, 57, 58, 59, 50, 54, 43, 88, 64, - 40, 69, 44, 89, 29, 62, 84, 13, 0, 82, - 65, 52, 86, 27, 74, 63, 15, 0, 0, 71, - 83, 160, 161, 162, 163, 169, 168, 167, 158, 159, - 103, 0, 160, 161, 162, 163, 169, 168, 167, 158, - 159, 103, 0, 0, 32, 160, 161, 162, 163, 169, - 168, 167, 158, 159, 103, 0, 160, 161, 162, 163, - 169, 168, 167, 158, 159, 103, 0, 160, 161, 162, - 163, 169, 168, 167, 158, 159, 103, 0, 160, 161, - 162, 163, 169, 168, 167, 158, 159, 103, 0, 0, - 233, 0, 0, 0, 0, 0, 165, 166, 363, 0, - 364, 233, 227, 0, 0, 0, 238, 165, 166, 231, - 0, 0, 0, 0, 233, 0, 0, 238, 0, 0, - 165, 166, 473, 0, 0, 233, 0, 0, 0, 0, - 238, 165, 166, 231, 0, 0, 233, 0, 0, 0, - 0, 238, 165, 166, 425, 0, 0, 233, 0, 0, - 0, 0, 238, 165, 166, 0, 0, 0, 0, 0, - 0, 0, 0, 238, 160, 161, 162, 163, 169, 168, - 167, 158, 159, 103, 0, 160, 161, 162, 163, 169, - 168, 167, 158, 159, 103, 160, 161, 162, 163, 169, - 168, 167, 158, 159, 103, 0, 0, 0, 160, 161, - 162, 163, 169, 168, 167, 158, 159, 103, 256, 0, - 93, 160, 161, 162, 163, 169, 168, 167, 158, 159, - 103, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 276, 0, 0, 0, 0, 0, 165, - 166, 0, 122, 0, 322, 125, 126, 127, 0, 238, - 165, 166, 0, 0, 0, 0, 0, 138, 139, 0, - 238, 140, 0, 142, 143, 144, 0, 251, 145, 146, - 147, 0, 148, 165, 166, 253, 0, 254, 0, 0, - 153, 0, 0, 0, 0, 0, 165, 166, 151, 0, - 152, 178, 179, 180, 181, 182, 160, 161, 162, 163, - 169, 168, 167, 158, 159, 103, 160, 161, 162, 163, - 169, 168, 167, 158, 159, 103, 160, 161, 162, 163, - 169, 168, 167, 158, 159, 103, 160, 161, 162, 163, - 169, 168, 167, 158, 159, 103, 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, 251, 0, 0, 0, 0, - 0, 165, 166, 283, 0, 153, 0, 0, 0, 0, - 0, 165, 166, 175, 0, 404, 0, 0, 0, 0, - 0, 165, 166, 56, 46, 251, 85, 0, 61, 0, - 90, 165, 166, 47, 73, 0, 0, 0, 70, 0, - 0, 66, 87, 0, 68, 72, 0, 67, 0, 57, - 58, 59, 50, 0, 0, 88, 0, 0, 0, 0, - 89, 0, 62, 84, 0, 64, 82, 69, 52, 86, - 0, 0, 63, 0, 124, 0, 65, 83, 0, 0, - 74, 0, 0, 0, 0, 71 }; -yytabelem yypact[]={ - --1000, 18, 503, 837,-1000,-1000,-1000,-1000,-1000,-1000, - 495,-1000,-1000,-1000,-1000,-1000,-1000, 164, 453, -35, - 194, 188, 187, 173, 58, 169, -8, 66,-1000,-1000, --1000,-1000,-1000,1264,-1000,-1000,-1000, -5,-1000,-1000, --1000,-1000,-1000,-1000,-1000, 453,-1000,-1000,-1000,-1000, --1000, 354,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000, --1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000, --1000,-1000,-1000,-1000,-1000,1096, 348,1191, 348, 165, --1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000, --1000,-1000,-1000,-1000, 453, 453, 453, 453,-1000, 453, --1000, 325,-1000,-1000, 453,-1000, -11, 453, 453, 453, - 343,-1000,-1000,-1000, 453, 159,-1000,-1000,-1000,-1000, - 468, 346, 58,-1000,-1000, 344,-1000,-1000,-1000,-1000, - 66, 453, 453, 343,-1000,-1000, 234, 342, 489,-1000, - 341, 917, 963, 963, 340, 475, 453, 335, 453,-1000, --1000,-1000,-1000,1083,-1000,-1000, 308,1211,-1000,-1000, --1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000,-1000, --1000,1083, 193, 158,-1000,-1000,1049,1049,-1000,-1000, --1000,-1000,1181, 332,-1000,-1000, 325, 325, 453,-1000, --1000, 73, 304,-1000, 58,-1000, 304,-1000,-1000,-1000, - 453,-1000, 380,-1000, 330,1273, -17, 66, -18, 453, - 475, 37, 963,1060,-1000, 453,-1000,-1000,-1000,-1000, --1000, 963,-1000, 963, 361,-1000, 963,-1000, 271,-1000, - 751, 475,-1000, 963,-1000,-1000,-1000, 963, 963,-1000, - 751,-1000, 963,-1000,-1000, 58, 475,-1000, 301, 240, --1000,1211,-1000,-1000,-1000, 906,-1000,1211,1211,1211, -1211,1211, -30, 204, 106, 388,-1000,-1000, 388, 388, --1000, 143, 135, 116, 751,-1000,1049,-1000,-1000,-1000, --1000,-1000, 308,-1000,-1000, 300,-1000,-1000, 325,-1000, --1000, 222,-1000,-1000,-1000, -5,-1000, -36,1201, 453, --1000, 216,-1000, 45,-1000,-1000, 380, 460,-1000, 453, --1000,-1000, 178,-1000, 226,-1000,-1000,-1000, 324, 220, - 726, 751, 952,-1000, 751, 299, 199, 115, 751, 453, - 704,-1000, 941, 963, 963, 963, 963, 963, 963, 963, - 963, 963, 963,-1000,-1000,-1000,-1000,-1000,-1000,-1000, - 676, 114, -31, 646, 629, 321, 127,-1000,-1000,-1000, -1083, 33, 751,-1000,-1000, 27, -30, -30, -30, 50, --1000, 388, 106, 107, 106,1049,1049,1049, 607, 88, - 86, 74,-1000,-1000,-1000, 87,-1000, 201,-1000, 304, --1000, 113,-1000, 85, 930,-1000,1201,-1000,-1000, -3, -1070,-1000,-1000,-1000, 963,-1000,-1000, 453,-1000, 380, - 64, 78,-1000, 8,-1000, 60,-1000,-1000, 453, 963, - 58, 963, 963, 391,-1000, 290, 303, 963, 963,-1000, - 475,-1000, 0, -31, -31, -31, 467, 95, 95, 581, - 646, -22,-1000, 963,-1000, 475, 475, 58,-1000, 308, --1000,-1000, 388,-1000,-1000,-1000,-1000,-1000,-1000,-1000, -1049,1049,1049,-1000, 466, 465, -5,-1000,-1000, 930, --1000,-1000, 564,-1000,-1000,1201,-1000,-1000,-1000,-1000, - 380,-1000, 460, 460, 453,-1000, 751, 37, 11, 43, - 751,-1000,-1000,-1000, 963, 285, 751, 41, 282, 62, --1000, 963, 284, 227, 282, 277, 275, 258,-1000,-1000, --1000,-1000, 930,-1000,-1000, 7, 248,-1000,-1000,-1000, --1000,-1000, 963,-1000,-1000, 475,-1000,-1000, 751,-1000, --1000,-1000,-1000,-1000, 751,-1000,-1000, 751, 34, 475, --1000 }; -yytabelem yypgo[]={ - - 0, 613, 612, 13, 611, 81, 15, 32, 610, 604, - 603, 10, 0, 602, 601, 600, 16, 598, 35, 25, - 597, 596, 595, 3, 4, 594, 67, 593, 592, 50, - 34, 18, 26, 101, 20, 591, 30, 373, 1, 292, - 24, 347, 327, 2, 9, 14, 31, 49, 46, 590, - 588, 39, 28, 45, 587, 585, 584, 583, 581,1100, - 40, 580, 579, 12, 578, 575, 573, 572, 571, 570, - 568, 29, 567, 27, 566, 23, 41, 7, 44, 6, - 37, 565, 38, 561, 560, 11, 22, 36, 559, 558, - 8, 17, 33, 557, 555, 541, 5, 540, 472, 537, - 536, 534, 533, 532, 528, 203, 523, 521, 518, 517, - 513, 509, 88, 508, 507, 19 }; -yytabelem yyr1[]={ - - 0, 1, 1, 55, 55, 55, 55, 55, 55, 55, - 2, 56, 56, 56, 56, 56, 56, 56, 60, 52, - 33, 53, 53, 61, 61, 62, 62, 63, 63, 26, - 26, 26, 27, 27, 34, 34, 17, 57, 57, 57, - 57, 57, 57, 57, 57, 57, 57, 57, 57, 10, - 10, 10, 74, 7, 8, 9, 9, 9, 9, 9, - 9, 9, 9, 9, 9, 9, 16, 16, 16, 50, - 50, 50, 50, 51, 51, 64, 64, 65, 65, 66, - 66, 80, 54, 54, 67, 67, 81, 82, 76, 83, - 84, 77, 77, 85, 85, 45, 45, 45, 70, 70, - 86, 86, 72, 72, 87, 36, 18, 18, 19, 19, - 75, 75, 89, 88, 88, 90, 90, 43, 43, 91, - 91, 3, 68, 68, 92, 92, 95, 93, 94, 94, - 96, 96, 11, 69, 69, 97, 20, 20, 71, 21, - 21, 22, 22, 38, 38, 38, 39, 39, 39, 39, - 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, - 12, 12, 13, 13, 13, 13, 13, 13, 37, 37, - 37, 37, 32, 40, 40, 44, 44, 48, 48, 48, - 48, 48, 48, 48, 47, 49, 49, 49, 41, 41, - 42, 42, 42, 42, 42, 42, 42, 42, 58, 58, - 58, 58, 58, 58, 58, 58, 58, 99, 23, 24, - 24, 98, 98, 98, 98, 98, 98, 98, 98, 98, - 98, 98, 4, 100, 101, 101, 101, 101, 73, 73, - 35, 25, 25, 46, 46, 14, 14, 28, 28, 59, - 78, 79, 102, 103, 103, 103, 103, 103, 103, 103, - 103, 103, 103, 103, 103, 103, 103, 104, 111, 111, - 111, 106, 113, 113, 113, 108, 108, 105, 105, 114, - 114, 115, 115, 115, 115, 115, 115, 15, 107, 109, - 110, 110, 29, 29, 6, 6, 30, 30, 30, 31, - 31, 31, 31, 31, 31, 5, 5, 5, 5, 5, - 112 }; -yytabelem yyr2[]={ - - 0, 0, 3, 2, 2, 2, 3, 3, 2, 1, - 1, 3, 4, 3, 4, 4, 5, 3, 0, 1, - 1, 0, 1, 2, 3, 1, 3, 1, 3, 0, - 2, 3, 1, 3, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 2, 1, 5, 7, - 5, 5, 0, 2, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 0, 4, 6, 3, - 4, 5, 3, 1, 3, 3, 3, 3, 3, 3, - 3, 3, 1, 3, 3, 3, 0, 6, 0, 0, - 0, 2, 3, 1, 3, 1, 2, 1, 1, 3, - 1, 1, 1, 3, 3, 2, 1, 5, 1, 3, - 0, 3, 0, 2, 3, 1, 3, 1, 1, 1, - 3, 1, 3, 3, 4, 1, 0, 2, 1, 3, - 1, 3, 1, 1, 2, 4, 1, 3, 0, 0, - 1, 1, 3, 1, 3, 1, 1, 1, 3, 3, - 3, 3, 2, 3, 3, 3, 3, 3, 2, 3, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, - 4, 5, 5, 0, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 5, 1, 1, 1, 1, 3, - 1, 1, 3, 3, 3, 3, 2, 3, 1, 7, - 4, 1, 2, 2, 6, 2, 2, 5, 3, 1, - 4, 4, 5, 2, 1, 1, 10, 1, 3, 4, - 3, 3, 1, 1, 3, 3, 7, 7, 0, 1, - 3, 1, 3, 1, 2, 1, 1, 1, 3, 0, - 0, 0, 1, 2, 2, 2, 2, 2, 2, 2, - 3, 4, 4, 2, 3, 1, 3, 3, 1, 1, - 1, 3, 1, 1, 1, 1, 1, 3, 3, 1, - 3, 1, 1, 1, 2, 2, 2, 1, 3, 3, - 4, 4, 1, 3, 1, 5, 1, 1, 1, 3, - 3, 3, 3, 3, 3, 1, 3, 5, 5, 5, - 0 }; -yytabelem yychk[]={ - --1000, -1, -55, -2, 256, 3, 1, -56, -57, -58, - 18, 37, 4, 60, 23, 69, 44, -7, 40, -10, - -50, -64, -65, -66, -67, -68, -69, 66, 43, 57, - -98, 33, 97, -99, 36, 35, 39, -8, 27, 42, - 53, 41, 30, 50, 55,-100, 20, 29,-101,-102, - 48, -35, 64, -14, 49, -9, 19, 45, 46, 47, --103, 24, 58, 68, 52, 63, 28, 34, 31, 54, - 25, 72, 32, 21, 67,-104,-106,-107,-109,-110, --111,-113, 62, 73, 59, 22, 65, 38, 51, 56, - 26, -17, 5, -59, -60, -60, -60, -60, 44, -73, - 78, -52, -33, 14, 78, 99, -73, 78, 78, 78, - 78, -73, 78, -97, 83, -70, -86, -33, -51, 85, - 83, -71, -59, -98, 70, -59, -59, -59, -16, 82, - -71, -71, -71, -71, -81, -71, -37, -33, -59, -59, - -59, 74, -59, -59, -59, -59, -59, -59, -59,-105, - -42, 82, 84, 74, -37, -48, -41, -12, 12, 13, - 5, 6, 7, 8, -49, 80, 81, 11, 10, 9, --105, 74,-105,-108, -42, 82,-105, 78, -59, -59, - -59, -59, -59, -53, -52, -53, -52, -52, -60, -33, - -26, 74, -33, -76, -51, -36, -33, -33, -33, -80, - 74, -82, -76, -92, -93, -95, -33, 78, 14, 74, - -78, -73, 74, -78, -36, -51, -33, -33, -80, -82, - -92, 76, -32, 74, -4, 6, 74, 75, -25, -46, - -38, 82, -39, 74, -47, -37, -48, -12, 90, -40, - -38, -40, 74, -3, 6, -33, 74, -33, -41,-114, - -42, 74,-115, 82, 84, -15, 15, -12, 82, 83, - 84, 85, -41, -41, -29, 78, -6, -37, 74, 78, - -30, -39, -5, -31, -38, -47, 74, -30,-112,-112, --112,-112, -41, 82, -61, 74, -26, -26, -52, -71, - 75, -27, -34, -33, 82, -75, 74, -77, -84, -73, - -75, -54, -37, -19, -18, -37, 74, 74, -7, 83, - -86, 83, -72, -87, -33, -3, -24, -23, 98, -33, - -38, -38, 74, -36, -38, -21, -40, -22, -38, 71, - -38, 75, 78, -12, 82, 83, 84, -13, 89, 88, - 87, 86, 85, 91, 93, 92, 95, 94, 96, -3, - -38, -39, -38, -38, -38, -73, -91, -3, 75, 75, - 78, -41, -38, 82, 84, -41, -41, -41, -41, -41, - 75, 78, -29, -29, -29, 78, 78, 78, -38, -39, - -5, -31,-112,-112, 75, -62, -63, 14, -26, -74, - 75, 78, -16, -88, -89, 99, 78, -85, -45, -44, - -12, -47, -33, -48, 74, -36, 75, 78, 83, 78, - -19, -94, -96, -11, 14, -20, -33, 75, 78, 76, - -79, 74, 76, 75, -79, 82, 75, 77, 78, -33, - 75, -46, -38, -38, -38, -38, -38, -38, -38, -38, - -38, -38, 75, 78, 75, 74, 78, 75,-115, -41, - 75, -6, 78, -39, -5, -39, -5, -39, -5, 75, - 78, 78, 78, 75, 78, 76, -75, -34, 75, 78, - -90, -43, -38, 82, -85, 82, -44, -37, -83, -18, - 78, 75, 78, 81, 78, -87, -38, -73, -38, -28, - -38, 70, 75, -32, 74, -40, -38, -3, -39, -91, - -3, -73, -23, -33, -39, -23, -23, -23, -63, 14, - -16, -90, 77, -45, -44, -77, -23, -96, -11, -33, - -24, 75, 78, -79, 75, 78, 75, 75, -38, 75, - 75, 75, 75, -43, -38, 83, 75, -38, -3, 78, - -3 }; -yytabelem yydef[]={ - - 1, -2, 0, 0, 9, 10, 2, 3, 4, 5, - 0, 239, 8, 18, 18, 18, 18, 228, 0, 37, - -2, 39, 40, 41, -2, 43, 44, 45, 47, 138, - 198, 239, 201, 0, 239, 239, 239, 66, 138, 138, - 138, 138, 86, 138, 133, 0, 239, 239, 214, 215, - 239, 217, 239, 239, 239, 54, 223, 239, 239, 239, - 242, 239, 235, 236, 55, 56, 57, 58, 59, 60, - 61, 62, 63, 64, 65, 0, 0, 0, 0, 255, - 239, 239, 239, 239, 239, 258, 259, 260, 262, 263, - 264, 6, 36, 7, 21, 21, 0, 0, 18, 0, - 229, 29, 19, 20, 0, 88, 0, 229, 0, 0, - 0, 88, 126, 134, 0, 46, 98, 100, 101, 73, - 0, 0, -2, 202, 203, 0, 205, 206, 53, 240, - 0, 0, 0, 0, 88, 126, 0, 168, 0, 213, - 0, 0, 173, 173, 0, 0, 0, 0, 0, 243, - -2, 245, 246, 0, 190, 191, 0, 0, 177, 178, - 179, 180, 181, 182, 183, 160, 161, 185, 186, 187, - 247, 0, 248, 249, -2, 266, 253, 0, 300, 300, - 300, 300, 0, 11, 22, 13, 29, 29, 0, 138, - 17, 0, 110, 90, 228, 72, 110, 76, 78, 80, - 0, 85, 0, 123, 125, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 69, 0, 75, 77, 79, 84, - 122, 0, 169, -2, 0, 222, 0, 218, 0, 231, - 233, 0, 143, 0, 145, 146, 147, 0, 0, 220, - 174, 221, 0, 224, 121, -2, 0, 230, 271, 0, - 188, 0, 269, 272, 273, 0, 277, 0, 0, 0, - 0, 0, 196, 271, 250, 0, 282, 284, 0, 0, - 254, -2, 287, 288, 0, -2, 0, 256, 257, 261, - 278, 279, 300, 300, 12, 0, 14, 15, 29, 52, - 30, 0, 32, 34, 35, 66, 112, 0, 0, 0, - 105, 0, 82, 0, 108, 106, 0, 0, 127, 0, - 99, 74, 0, 102, 0, 241, 200, 209, 0, 0, - 0, 241, 0, 70, 211, 0, 0, 140, -2, 0, - 0, 219, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 162, 163, 164, 165, 166, 167, 234, - 0, 143, 152, 158, 0, 0, 0, 119, -2, 268, - 0, 0, 274, 275, 276, 192, 193, 194, 195, 197, - 267, 0, 252, 0, 251, 0, 0, 0, 0, 143, - 0, 0, 280, 281, 23, 0, 25, 27, 16, 110, - 31, 0, 50, 0, 0, 51, 0, 91, 93, 95, - 0, 97, 175, 176, 0, 71, 81, 0, 89, 0, - 0, 0, 128, 130, 132, 135, 136, 48, 0, 0, - 228, 0, 0, 0, 67, 0, 170, 173, 0, 212, - 0, 232, 148, 149, 150, 151, -2, 154, 155, 156, - 157, 159, 144, 0, 207, 0, 0, 228, 270, 271, - 189, 283, 0, -2, 290, -2, 292, -2, 294, -2, - 0, 0, 0, 24, 0, 0, 66, 33, 111, 0, - 113, 115, 118, 117, 92, 0, 96, 83, 90, 109, - 0, 124, 0, 0, 0, 103, 104, 0, 0, 208, - 237, 204, 241, 171, 173, 0, 142, 0, 143, 0, - 120, 0, 0, 168, -2, 0, 0, 0, 26, 28, - 49, 114, 0, 94, 95, 0, 0, 129, 131, 137, - 199, 210, 0, 68, 172, 0, 184, 226, 227, 285, - 297, 298, 299, 116, 118, 87, 107, 238, 0, 0, - 216 }; -# ifdef YYDEBUG -# include "y.debug" -# endif - -# define YYFLAG -1000 -# define YYERROR goto yyerrlab -# define YYACCEPT return(0) -# define YYABORT return(1) - -/* parser for yacc output */ - -#ifdef YYDEBUG -int yydebug = 0; /* 1 for debugging */ -#endif -YYSTYPE yyv[YYMAXDEPTH]; /* where the values are stored */ -int yychar = -1; /* current input token number */ -int yynerrs = 0; /* number of errors */ -yytabelem yyerrflag = 0; /* error recovery flag */ - -yyparse() -{ yytabelem yys[YYMAXDEPTH]; - int yyj, yym; - register YYSTYPE *yypvt; - register int yystate, yyn; - register yytabelem *yyps; - register YYSTYPE *yypv; - register yytabelem *yyxi; - - yystate = 0; - yychar = -1; - yynerrs = 0; - yyerrflag = 0; - yyps= &yys[-1]; - yypv= &yyv[-1]; - -yystack: /* put a state and value onto the stack */ -#ifdef YYDEBUG - if(yydebug >= 3) - if(yychar < 0 || yytoknames[yychar] == 0) - printf("char %d in %s", yychar, yystates[yystate]); - else - printf("%s in %s", yytoknames[yychar], yystates[yystate]); -#endif - if( ++yyps >= &yys[YYMAXDEPTH] ) { - yyerror( "yacc stack overflow" ); - return(1); - } - *yyps = yystate; - ++yypv; - *yypv = yyval; -yynewstate: - yyn = yypact[yystate]; - if(yyn <= YYFLAG) goto yydefault; /* simple state */ - if(yychar<0) { - yychar = yylex(); -#ifdef YYDEBUG - if(yydebug >= 2) { - if(yychar <= 0) - printf("lex EOF\n"); - else if(yytoknames[yychar]) - printf("lex %s\n", yytoknames[yychar]); - else - printf("lex (%c)\n", yychar); - } -#endif - if(yychar < 0) - yychar = 0; - } - if((yyn += yychar) < 0 || yyn >= YYLAST) - goto yydefault; - if( yychk[ yyn=yyact[ yyn ] ] == yychar ){ /* valid shift */ - yychar = -1; - yyval = yylval; - yystate = yyn; - if( yyerrflag > 0 ) --yyerrflag; - goto yystack; - } -yydefault: - /* default state action */ - if( (yyn=yydef[yystate]) == -2 ) { - if(yychar < 0) { - yychar = yylex(); -#ifdef YYDEBUG - if(yydebug >= 2) - if(yychar < 0) - printf("lex EOF\n"); - else - printf("lex %s\n", yytoknames[yychar]); -#endif - if(yychar < 0) - yychar = 0; - } - /* look through exception table */ - for(yyxi=yyexca; (*yyxi!= (-1)) || (yyxi[1]!=yystate); - yyxi += 2 ) ; /* VOID */ - while( *(yyxi+=2) >= 0 ){ - if( *yyxi == yychar ) break; - } - if( (yyn = yyxi[1]) < 0 ) return(0); /* accept */ - } - if( yyn == 0 ){ /* error */ - /* error ... attempt to resume parsing */ - switch( yyerrflag ){ - case 0: /* brand new error */ -#ifdef YYDEBUG - yyerror("syntax error\n%s", yystates[yystate]); - if(yytoknames[yychar]) - yyerror("saw %s\n", yytoknames[yychar]); - else if(yychar >= ' ' && yychar < '\177') - yyerror("saw `%c'\n", yychar); - else if(yychar == 0) - yyerror("saw EOF\n"); - else - yyerror("saw char 0%o\n", yychar); -#else - yyerror( "syntax error" ); -#endif -yyerrlab: - ++yynerrs; - case 1: - case 2: /* incompletely recovered error ... try again */ - yyerrflag = 3; - /* find a state where "error" is a legal shift action */ - while ( yyps >= yys ) { - yyn = yypact[*yyps] + YYERRCODE; - if( yyn>= 0 && yyn < YYLAST && yychk[yyact[yyn]] == YYERRCODE ){ - yystate = yyact[yyn]; /* simulate a shift of "error" */ - goto yystack; - } - yyn = yypact[*yyps]; - /* the current yyps has no shift onn "error", pop stack */ -#ifdef YYDEBUG - if( yydebug ) printf( "error recovery pops state %d, uncovers %d\n", *yyps, yyps[-1] ); -#endif - --yyps; - --yypv; - } - /* there is no state on the stack with an error shift ... abort */ -yyabort: - return(1); - case 3: /* no shift yet; clobber input char */ -#ifdef YYDEBUG - if( yydebug ) { - printf("error recovery discards "); - if(yytoknames[yychar]) - printf("%s\n", yytoknames[yychar]); - else if(yychar >= ' ' && yychar < '\177') - printf("`%c'\n", yychar); - else if(yychar == 0) - printf("EOF\n"); - else - printf("char 0%o\n", yychar); - } -#endif - if( yychar == 0 ) goto yyabort; /* don't discard EOF, quit */ - yychar = -1; - goto yynewstate; /* try again in the same state */ - } - } - /* reduction by production yyn */ -#ifdef YYDEBUG - if(yydebug) { char *s; - printf("reduce %d in:\n\t", yyn); - for(s = yystates[yystate]; *s; s++) { - putchar(*s); - if(*s == '\n' && *(s+1)) - putchar('\t'); - } - } -#endif - yyps -= yyr2[yyn]; - yypvt = yypv; - yypv -= yyr2[yyn]; - yyval = yypv[1]; - yym=yyn; - /* consult goto table to find next state */ - yyn = yyr1[yyn]; - yyj = yypgo[yyn] + *yyps + 1; - if( yyj>=YYLAST || yychk[ yystate = yyact[yyj] ] != -yyn ) yystate = yyact[yypgo[yyn]]; - switch(yym){ - -case 3: -/* # line 226 "gram.in" */ -{ -/* stat: is the nonterminal for Fortran statements */ - - lastwasbranch = NO; } break; -case 5: -/* # line 232 "gram.in" */ -{ /* forbid further statement function definitions... */ - if (parstate == INDATA && laststfcn != thisstno) - parstate = INEXEC; - thisstno++; - if(yypvt[-1].labval && (yypvt[-1].labval->labelno==dorange)) - enddo(yypvt[-1].labval->labelno); - if(lastwasbranch && thislabel==NULL) - warn("statement cannot be reached"); - lastwasbranch = thiswasbranch; - thiswasbranch = NO; - if(yypvt[-1].labval) - { - if(yypvt[-1].labval->labtype == LABFORMAT) - err("label already that of a format"); - else - yypvt[-1].labval->labtype = LABEXEC; - } - freetemps(); - } break; -case 6: -/* # line 252 "gram.in" */ -{ if (can_include) - doinclude( yypvt[-0].charpval ); - else { - fprintf(diagfile, "Cannot open file %s\n", yypvt[-0].charpval); - done(1); - } - } break; -case 7: -/* # line 260 "gram.in" */ -{ if (yypvt[-2].labval) - lastwasbranch = NO; - endproc(); /* lastwasbranch = NO; -- set in endproc() */ - } break; -case 8: -/* # line 265 "gram.in" */ -{ extern void unclassifiable(); - unclassifiable(); - -/* flline flushes the current line, ignoring the rest of the text there */ - - flline(); } break; -case 9: -/* # line 272 "gram.in" */ -{ flline(); needkwd = NO; inioctl = NO; - yyerrok; yyclearin; } break; -case 10: -/* # line 277 "gram.in" */ -{ - if(yystno != 0) - { - yyval.labval = thislabel = mklabel(yystno); - if( ! headerdone ) { - if (procclass == CLUNKNOWN) - procclass = CLMAIN; - puthead(CNULL, procclass); - } - if(thislabel->labdefined) - execerr("label %s already defined", - convic(thislabel->stateno) ); - else { - if(thislabel->blklevel!=0 && thislabel->blklevel<blklevel - && thislabel->labtype!=LABFORMAT) - warn1("there is a branch to label %s from outside block", - convic( (ftnint) (thislabel->stateno) ) ); - thislabel->blklevel = blklevel; - thislabel->labdefined = YES; - if(thislabel->labtype != LABFORMAT) - p1_label((long)(thislabel - labeltab)); - } - } - else yyval.labval = thislabel = NULL; - } break; -case 11: -/* # line 305 "gram.in" */ -{startproc(yypvt[-0].extval, CLMAIN); } break; -case 12: -/* # line 307 "gram.in" */ -{ warn("ignoring arguments to main program"); - /* hashclear(); */ - startproc(yypvt[-1].extval, CLMAIN); } break; -case 13: -/* # line 311 "gram.in" */ -{ if(yypvt[-0].extval) NO66("named BLOCKDATA"); - startproc(yypvt[-0].extval, CLBLOCK); } break; -case 14: -/* # line 314 "gram.in" */ -{ entrypt(CLPROC, TYSUBR, (ftnint) 0, yypvt[-1].extval, yypvt[-0].chval); } break; -case 15: -/* # line 316 "gram.in" */ -{ entrypt(CLPROC, TYUNKNOWN, (ftnint) 0, yypvt[-1].extval, yypvt[-0].chval); } break; -case 16: -/* # line 318 "gram.in" */ -{ entrypt(CLPROC, yypvt[-4].ival, varleng, yypvt[-1].extval, yypvt[-0].chval); } break; -case 17: -/* # line 320 "gram.in" */ -{ if(parstate==OUTSIDE || procclass==CLMAIN - || procclass==CLBLOCK) - execerr("misplaced entry statement", CNULL); - entrypt(CLENTRY, 0, (ftnint) 0, yypvt[-1].extval, yypvt[-0].chval); - } break; -case 18: -/* # line 328 "gram.in" */ -{ newproc(); } break; -case 19: -/* # line 332 "gram.in" */ -{ yyval.extval = newentry(yypvt[-0].namval, 1); } break; -case 20: -/* # line 336 "gram.in" */ -{ yyval.namval = mkname(token); } break; -case 21: -/* # line 339 "gram.in" */ -{ yyval.extval = NULL; } break; -case 29: -/* # line 357 "gram.in" */ -{ yyval.chval = 0; } break; -case 30: -/* # line 359 "gram.in" */ -{ NO66(" () argument list"); - yyval.chval = 0; } break; -case 31: -/* # line 362 "gram.in" */ -{yyval.chval = yypvt[-1].chval; } break; -case 32: -/* # line 366 "gram.in" */ -{ yyval.chval = (yypvt[-0].namval ? mkchain((char *)yypvt[-0].namval,CHNULL) : CHNULL ); } break; -case 33: -/* # line 368 "gram.in" */ -{ if(yypvt[-0].namval) yypvt[-2].chval = yyval.chval = mkchain((char *)yypvt[-0].namval, yypvt[-2].chval); } break; -case 34: -/* # line 372 "gram.in" */ -{ if(yypvt[-0].namval->vstg!=STGUNKNOWN && yypvt[-0].namval->vstg!=STGARG) - dclerr("name declared as argument after use", yypvt[-0].namval); - yypvt[-0].namval->vstg = STGARG; - } break; -case 35: -/* # line 377 "gram.in" */ -{ NO66("altenate return argument"); - -/* substars means that '*'ed formal parameters should be replaced. - This is used to specify alternate return labels; in theory, only - parameter slots which have '*' should accept the statement labels. - This compiler chooses to ignore the '*'s in the formal declaration, and - always return the proper value anyway. - - This variable is only referred to in proc.c */ - - yyval.namval = 0; substars = YES; } break; -case 36: -/* # line 393 "gram.in" */ -{ - char *s; - s = copyn(toklen+1, token); - s[toklen] = '\0'; - yyval.charpval = s; - } break; -case 45: -/* # line 409 "gram.in" */ -{ NO66("SAVE statement"); - saveall = YES; } break; -case 46: -/* # line 412 "gram.in" */ -{ NO66("SAVE statement"); } break; -case 47: -/* # line 414 "gram.in" */ -{ fmtstmt(thislabel); setfmt(thislabel); } break; -case 48: -/* # line 416 "gram.in" */ -{ NO66("PARAMETER statement"); } break; -case 49: -/* # line 420 "gram.in" */ -{ settype(yypvt[-4].namval, yypvt[-6].ival, yypvt[-0].lval); - if(ndim>0) setbound(yypvt[-4].namval,ndim,dims); - } break; -case 50: -/* # line 424 "gram.in" */ -{ settype(yypvt[-2].namval, yypvt[-4].ival, yypvt[-0].lval); - if(ndim>0) setbound(yypvt[-2].namval,ndim,dims); - } break; -case 51: -/* # line 428 "gram.in" */ -{ if (new_dcl == 2) { - err("attempt to give DATA in type-declaration"); - new_dcl = 1; - } - } break; -case 52: -/* # line 435 "gram.in" */ -{ new_dcl = 2; } break; -case 53: -/* # line 438 "gram.in" */ -{ varleng = yypvt[-0].lval; } break; -case 54: -/* # line 442 "gram.in" */ -{ varleng = (yypvt[-0].ival<0 || ONEOF(yypvt[-0].ival,M(TYLOGICAL)|M(TYLONG)) - ? 0 : typesize[yypvt[-0].ival]); - vartype = yypvt[-0].ival; } break; -case 55: -/* # line 447 "gram.in" */ -{ yyval.ival = TYLONG; } break; -case 56: -/* # line 448 "gram.in" */ -{ yyval.ival = tyreal; } break; -case 57: -/* # line 449 "gram.in" */ -{ ++complex_seen; yyval.ival = tycomplex; } break; -case 58: -/* # line 450 "gram.in" */ -{ yyval.ival = TYDREAL; } break; -case 59: -/* # line 451 "gram.in" */ -{ ++dcomplex_seen; NOEXT("DOUBLE COMPLEX statement"); yyval.ival = TYDCOMPLEX; } break; -case 60: -/* # line 452 "gram.in" */ -{ yyval.ival = TYLOGICAL; } break; -case 61: -/* # line 453 "gram.in" */ -{ NO66("CHARACTER statement"); yyval.ival = TYCHAR; } break; -case 62: -/* # line 454 "gram.in" */ -{ yyval.ival = TYUNKNOWN; } break; -case 63: -/* # line 455 "gram.in" */ -{ yyval.ival = TYUNKNOWN; } break; -case 64: -/* # line 456 "gram.in" */ -{ NOEXT("AUTOMATIC statement"); yyval.ival = - STGAUTO; } break; -case 65: -/* # line 457 "gram.in" */ -{ NOEXT("STATIC statement"); yyval.ival = - STGBSS; } break; -case 66: -/* # line 461 "gram.in" */ -{ yyval.lval = varleng; } break; -case 67: -/* # line 463 "gram.in" */ -{ - expptr p; - p = yypvt[-1].expval; - NO66("length specification *n"); - if( ! ISICON(p) || p->constblock.Const.ci <= 0 ) - { - yyval.lval = 0; - dclerr("length must be a positive integer constant", - NPNULL); - } - else { - if (vartype == TYCHAR) - yyval.lval = p->constblock.Const.ci; - else switch((int)p->constblock.Const.ci) { - case 1: yyval.lval = 1; break; - case 2: yyval.lval = typesize[TYSHORT]; break; - case 4: yyval.lval = typesize[TYLONG]; break; - case 8: yyval.lval = typesize[TYDREAL]; break; - case 16: yyval.lval = typesize[TYDCOMPLEX]; break; - default: - dclerr("invalid length",NPNULL); - yyval.lval = varleng; - } - } - } break; -case 68: -/* # line 489 "gram.in" */ -{ NO66("length specification *(*)"); yyval.lval = -1; } break; -case 69: -/* # line 493 "gram.in" */ -{ incomm( yyval.extval = comblock("") , yypvt[-0].namval ); } break; -case 70: -/* # line 495 "gram.in" */ -{ yyval.extval = yypvt[-1].extval; incomm(yypvt[-1].extval, yypvt[-0].namval); } break; -case 71: -/* # line 497 "gram.in" */ -{ yyval.extval = yypvt[-2].extval; incomm(yypvt[-2].extval, yypvt[-0].namval); } break; -case 72: -/* # line 499 "gram.in" */ -{ incomm(yypvt[-2].extval, yypvt[-0].namval); } break; -case 73: -/* # line 503 "gram.in" */ -{ yyval.extval = comblock(""); } break; -case 74: -/* # line 505 "gram.in" */ -{ yyval.extval = comblock(token); } break; -case 75: -/* # line 509 "gram.in" */ -{ setext(yypvt[-0].namval); } break; -case 76: -/* # line 511 "gram.in" */ -{ setext(yypvt[-0].namval); } break; -case 77: -/* # line 515 "gram.in" */ -{ NO66("INTRINSIC statement"); setintr(yypvt[-0].namval); } break; -case 78: -/* # line 517 "gram.in" */ -{ setintr(yypvt[-0].namval); } break; -case 81: -/* # line 525 "gram.in" */ -{ - struct Equivblock *p; - if(nequiv >= maxequiv) - many("equivalences", 'q', maxequiv); - p = & eqvclass[nequiv++]; - p->eqvinit = NO; - p->eqvbottom = 0; - p->eqvtop = 0; - p->equivs = yypvt[-1].eqvval; - } break; -case 82: -/* # line 538 "gram.in" */ -{ yyval.eqvval=ALLOC(Eqvchain); - yyval.eqvval->eqvitem.eqvlhs = (struct Primblock *)yypvt[-0].expval; - } break; -case 83: -/* # line 542 "gram.in" */ -{ yyval.eqvval=ALLOC(Eqvchain); - yyval.eqvval->eqvitem.eqvlhs = (struct Primblock *) yypvt[-0].expval; - yyval.eqvval->eqvnextp = yypvt[-2].eqvval; - } break; -case 86: -/* # line 553 "gram.in" */ -{ if(parstate == OUTSIDE) - { - newproc(); - startproc(ESNULL, CLMAIN); - } - if(parstate < INDATA) - { - enddcl(); - parstate = INDATA; - datagripe = 1; - } - } break; -case 87: -/* # line 568 "gram.in" */ -{ ftnint junk; - if(nextdata(&junk) != NULL) - err("too few initializers"); - frdata(yypvt[-4].chval); - frrpl(); - } break; -case 88: -/* # line 576 "gram.in" */ -{ frchain(&datastack); curdtp = 0; } break; -case 89: -/* # line 578 "gram.in" */ -{ pop_datastack(); } break; -case 90: -/* # line 580 "gram.in" */ -{ toomanyinit = NO; } break; -case 93: -/* # line 585 "gram.in" */ -{ dataval(ENULL, yypvt[-0].expval); } break; -case 94: -/* # line 587 "gram.in" */ -{ dataval(yypvt[-2].expval, yypvt[-0].expval); } break; -case 96: -/* # line 592 "gram.in" */ -{ if( yypvt[-1].ival==OPMINUS && ISCONST(yypvt[-0].expval) ) - consnegop((Constp)yypvt[-0].expval); - yyval.expval = yypvt[-0].expval; - } break; -case 100: -/* # line 604 "gram.in" */ -{ int k; - yypvt[-0].namval->vsave = YES; - k = yypvt[-0].namval->vstg; - if( ! ONEOF(k, M(STGUNKNOWN)|M(STGBSS)|M(STGINIT)) ) - dclerr("can only save static variables", yypvt[-0].namval); - } break; -case 104: -/* # line 618 "gram.in" */ -{ if(yypvt[-2].namval->vclass == CLUNKNOWN) - make_param((struct Paramblock *)yypvt[-2].namval, yypvt[-0].expval); - else dclerr("cannot make into parameter", yypvt[-2].namval); - } break; -case 105: -/* # line 625 "gram.in" */ -{ if(ndim>0) setbound(yypvt[-1].namval, ndim, dims); } break; -case 106: -/* # line 629 "gram.in" */ -{ Namep np; - np = ( (struct Primblock *) yypvt[-0].expval) -> namep; - vardcl(np); - if(np->vstg == STGCOMMON) - extsymtab[np->vardesc.varno].extinit = YES; - else if(np->vstg==STGEQUIV) - eqvclass[np->vardesc.varno].eqvinit = YES; - else if(np->vstg!=STGINIT && np->vstg!=STGBSS) - dclerr("inconsistent storage classes", np); - yyval.chval = mkchain((char *)yypvt[-0].expval, CHNULL); - } break; -case 107: -/* # line 641 "gram.in" */ -{ chainp p; struct Impldoblock *q; - pop_datastack(); - q = ALLOC(Impldoblock); - q->tag = TIMPLDO; - (q->varnp = (Namep) (yypvt[-1].chval->datap))->vimpldovar = 1; - p = yypvt[-1].chval->nextp; - if(p) { q->implb = (expptr)(p->datap); p = p->nextp; } - if(p) { q->impub = (expptr)(p->datap); p = p->nextp; } - if(p) { q->impstep = (expptr)(p->datap); } - frchain( & (yypvt[-1].chval) ); - yyval.chval = mkchain((char *)q, CHNULL); - q->datalist = hookup(yypvt[-3].chval, yyval.chval); - } break; -case 108: -/* # line 657 "gram.in" */ -{ if (!datastack) - curdtp = 0; - datastack = mkchain((char *)curdtp, datastack); - curdtp = yypvt[-0].chval; curdtelt = 0; - } break; -case 109: -/* # line 663 "gram.in" */ -{ yyval.chval = hookup(yypvt[-2].chval, yypvt[-0].chval); } break; -case 110: -/* # line 667 "gram.in" */ -{ ndim = 0; } break; -case 112: -/* # line 671 "gram.in" */ -{ ndim = 0; } break; -case 115: -/* # line 676 "gram.in" */ -{ - if(ndim == maxdim) - err("too many dimensions"); - else if(ndim < maxdim) - { dims[ndim].lb = 0; - dims[ndim].ub = yypvt[-0].expval; - } - ++ndim; - } break; -case 116: -/* # line 686 "gram.in" */ -{ - if(ndim == maxdim) - err("too many dimensions"); - else if(ndim < maxdim) - { dims[ndim].lb = yypvt[-2].expval; - dims[ndim].ub = yypvt[-0].expval; - } - ++ndim; - } break; -case 117: -/* # line 698 "gram.in" */ -{ yyval.expval = 0; } break; -case 119: -/* # line 703 "gram.in" */ -{ nstars = 1; labarray[0] = yypvt[-0].labval; } break; -case 120: -/* # line 705 "gram.in" */ -{ if(nstars < maxlablist) labarray[nstars++] = yypvt[-0].labval; } break; -case 121: -/* # line 709 "gram.in" */ -{ yyval.labval = execlab( convci(toklen, token) ); } break; -case 122: -/* # line 713 "gram.in" */ -{ NO66("IMPLICIT statement"); } break; -case 125: -/* # line 719 "gram.in" */ -{ if (vartype != TYUNKNOWN) - dclerr("-- expected letter range",NPNULL); - setimpl(vartype, varleng, 'a', 'z'); } break; -case 126: -/* # line 724 "gram.in" */ -{ needkwd = 1; } break; -case 130: -/* # line 733 "gram.in" */ -{ setimpl(vartype, varleng, yypvt[-0].ival, yypvt[-0].ival); } break; -case 131: -/* # line 735 "gram.in" */ -{ setimpl(vartype, varleng, yypvt[-2].ival, yypvt[-0].ival); } break; -case 132: -/* # line 739 "gram.in" */ -{ if(toklen!=1 || token[0]<'a' || token[0]>'z') - { - dclerr("implicit item must be single letter", NPNULL); - yyval.ival = 0; - } - else yyval.ival = token[0]; - } break; -case 135: -/* # line 753 "gram.in" */ -{ - if(yypvt[-2].namval->vclass == CLUNKNOWN) - { - yypvt[-2].namval->vclass = CLNAMELIST; - yypvt[-2].namval->vtype = TYINT; - yypvt[-2].namval->vstg = STGBSS; - yypvt[-2].namval->varxptr.namelist = yypvt[-0].chval; - yypvt[-2].namval->vardesc.varno = ++lastvarno; - } - else dclerr("cannot be a namelist name", yypvt[-2].namval); - } break; -case 136: -/* # line 767 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].namval, CHNULL); } break; -case 137: -/* # line 769 "gram.in" */ -{ yyval.chval = hookup(yypvt[-2].chval, mkchain((char *)yypvt[-0].namval, CHNULL)); } break; -case 138: -/* # line 773 "gram.in" */ -{ switch(parstate) - { - case OUTSIDE: newproc(); - startproc(ESNULL, CLMAIN); - case INSIDE: parstate = INDCL; - case INDCL: break; - - case INDATA: - if (datagripe) { - errstr( - "Statement order error: declaration after DATA", - CNULL); - datagripe = 0; - } - break; - - default: - dclerr("declaration among executables", NPNULL); - } - } break; -case 139: -/* # line 795 "gram.in" */ -{ yyval.chval = 0; } break; -case 140: -/* # line 797 "gram.in" */ -{ yyval.chval = revchain(yypvt[-0].chval); } break; -case 141: -/* # line 801 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, CHNULL); } break; -case 142: -/* # line 803 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, yypvt[-2].chval); } break; -case 144: -/* # line 808 "gram.in" */ -{ yyval.expval = yypvt[-1].expval; if (yyval.expval->tag == TPRIM) - yyval.expval->primblock.parenused = 1; } break; -case 148: -/* # line 816 "gram.in" */ -{ yyval.expval = mkexpr(yypvt[-1].ival, yypvt[-2].expval, yypvt[-0].expval); } break; -case 149: -/* # line 818 "gram.in" */ -{ yyval.expval = mkexpr(OPSTAR, yypvt[-2].expval, yypvt[-0].expval); } break; -case 150: -/* # line 820 "gram.in" */ -{ yyval.expval = mkexpr(OPSLASH, yypvt[-2].expval, yypvt[-0].expval); } break; -case 151: -/* # line 822 "gram.in" */ -{ yyval.expval = mkexpr(OPPOWER, yypvt[-2].expval, yypvt[-0].expval); } break; -case 152: -/* # line 824 "gram.in" */ -{ if(yypvt[-1].ival == OPMINUS) - yyval.expval = mkexpr(OPNEG, yypvt[-0].expval, ENULL); - else yyval.expval = yypvt[-0].expval; - } break; -case 153: -/* # line 829 "gram.in" */ -{ yyval.expval = mkexpr(yypvt[-1].ival, yypvt[-2].expval, yypvt[-0].expval); } break; -case 154: -/* # line 831 "gram.in" */ -{ NO66(".EQV. operator"); - yyval.expval = mkexpr(OPEQV, yypvt[-2].expval,yypvt[-0].expval); } break; -case 155: -/* # line 834 "gram.in" */ -{ NO66(".NEQV. operator"); - yyval.expval = mkexpr(OPNEQV, yypvt[-2].expval, yypvt[-0].expval); } break; -case 156: -/* # line 837 "gram.in" */ -{ yyval.expval = mkexpr(OPOR, yypvt[-2].expval, yypvt[-0].expval); } break; -case 157: -/* # line 839 "gram.in" */ -{ yyval.expval = mkexpr(OPAND, yypvt[-2].expval, yypvt[-0].expval); } break; -case 158: -/* # line 841 "gram.in" */ -{ yyval.expval = mkexpr(OPNOT, yypvt[-0].expval, ENULL); } break; -case 159: -/* # line 843 "gram.in" */ -{ NO66("concatenation operator //"); - yyval.expval = mkexpr(OPCONCAT, yypvt[-2].expval, yypvt[-0].expval); } break; -case 160: -/* # line 847 "gram.in" */ -{ yyval.ival = OPPLUS; } break; -case 161: -/* # line 848 "gram.in" */ -{ yyval.ival = OPMINUS; } break; -case 162: -/* # line 851 "gram.in" */ -{ yyval.ival = OPEQ; } break; -case 163: -/* # line 852 "gram.in" */ -{ yyval.ival = OPGT; } break; -case 164: -/* # line 853 "gram.in" */ -{ yyval.ival = OPLT; } break; -case 165: -/* # line 854 "gram.in" */ -{ yyval.ival = OPGE; } break; -case 166: -/* # line 855 "gram.in" */ -{ yyval.ival = OPLE; } break; -case 167: -/* # line 856 "gram.in" */ -{ yyval.ival = OPNE; } break; -case 168: -/* # line 860 "gram.in" */ -{ yyval.expval = mkprim(yypvt[-0].namval, LBNULL, CHNULL); } break; -case 169: -/* # line 862 "gram.in" */ -{ NO66("substring operator :"); - yyval.expval = mkprim(yypvt[-1].namval, LBNULL, yypvt[-0].chval); } break; -case 170: -/* # line 865 "gram.in" */ -{ yyval.expval = mkprim(yypvt[-3].namval, mklist(yypvt[-1].chval), CHNULL); } break; -case 171: -/* # line 867 "gram.in" */ -{ NO66("substring operator :"); - yyval.expval = mkprim(yypvt[-4].namval, mklist(yypvt[-2].chval), yypvt[-0].chval); } break; -case 172: -/* # line 872 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-3].expval, mkchain((char *)yypvt[-1].expval,CHNULL)); } break; -case 173: -/* # line 876 "gram.in" */ -{ yyval.expval = 0; } break; -case 175: -/* # line 881 "gram.in" */ -{ if(yypvt[-0].namval->vclass == CLPARAM) - yyval.expval = (expptr) cpexpr( - ( (struct Paramblock *) (yypvt[-0].namval) ) -> paramval); - } break; -case 177: -/* # line 888 "gram.in" */ -{ yyval.expval = mklogcon(1); } break; -case 178: -/* # line 889 "gram.in" */ -{ yyval.expval = mklogcon(0); } break; -case 179: -/* # line 890 "gram.in" */ -{ yyval.expval = mkstrcon(toklen, token); } break; -case 180: -/* # line 891 "gram.in" */ - { yyval.expval = mkintcon( convci(toklen, token) ); } break; -case 181: -/* # line 892 "gram.in" */ - { yyval.expval = mkrealcon(tyreal, token); } break; -case 182: -/* # line 893 "gram.in" */ - { yyval.expval = mkrealcon(TYDREAL, token); } break; -case 184: -/* # line 898 "gram.in" */ -{ yyval.expval = mkcxcon(yypvt[-3].expval,yypvt[-1].expval); } break; -case 185: -/* # line 902 "gram.in" */ -{ NOEXT("hex constant"); - yyval.expval = mkbitcon(4, toklen, token); } break; -case 186: -/* # line 905 "gram.in" */ -{ NOEXT("octal constant"); - yyval.expval = mkbitcon(3, toklen, token); } break; -case 187: -/* # line 908 "gram.in" */ -{ NOEXT("binary constant"); - yyval.expval = mkbitcon(1, toklen, token); } break; -case 189: -/* # line 914 "gram.in" */ -{ yyval.expval = yypvt[-1].expval; } break; -case 192: -/* # line 920 "gram.in" */ -{ yyval.expval = mkexpr(yypvt[-1].ival, yypvt[-2].expval, yypvt[-0].expval); } break; -case 193: -/* # line 922 "gram.in" */ -{ yyval.expval = mkexpr(OPSTAR, yypvt[-2].expval, yypvt[-0].expval); } break; -case 194: -/* # line 924 "gram.in" */ -{ yyval.expval = mkexpr(OPSLASH, yypvt[-2].expval, yypvt[-0].expval); } break; -case 195: -/* # line 926 "gram.in" */ -{ yyval.expval = mkexpr(OPPOWER, yypvt[-2].expval, yypvt[-0].expval); } break; -case 196: -/* # line 928 "gram.in" */ -{ if(yypvt[-1].ival == OPMINUS) - yyval.expval = mkexpr(OPNEG, yypvt[-0].expval, ENULL); - else yyval.expval = yypvt[-0].expval; - } break; -case 197: -/* # line 933 "gram.in" */ -{ NO66("concatenation operator //"); - yyval.expval = mkexpr(OPCONCAT, yypvt[-2].expval, yypvt[-0].expval); } break; -case 199: -/* # line 938 "gram.in" */ -{ - if(yypvt[-3].labval->labdefined) - execerr("no backward DO loops", CNULL); - yypvt[-3].labval->blklevel = blklevel+1; - exdo(yypvt[-3].labval->labelno, NPNULL, yypvt[-0].chval); - } break; -case 200: -/* # line 945 "gram.in" */ -{ - exdo((int)(ctls - ctlstack - 2), NPNULL, yypvt[-0].chval); - NOEXT("DO without label"); - } break; -case 201: -/* # line 950 "gram.in" */ -{ exenddo(NPNULL); } break; -case 202: -/* # line 952 "gram.in" */ -{ exendif(); thiswasbranch = NO; } break; -case 204: -/* # line 955 "gram.in" */ -{ exelif(yypvt[-2].expval); lastwasbranch = NO; } break; -case 205: -/* # line 957 "gram.in" */ -{ exelse(); lastwasbranch = NO; } break; -case 206: -/* # line 959 "gram.in" */ -{ exendif(); lastwasbranch = NO; } break; -case 207: -/* # line 963 "gram.in" */ -{ exif(yypvt[-1].expval); } break; -case 208: -/* # line 967 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-2].namval, yypvt[-0].chval); } break; -case 210: -/* # line 972 "gram.in" */ -{ yyval.chval = mkchain(CNULL, (chainp)yypvt[-1].expval); } break; -case 211: -/* # line 976 "gram.in" */ -{ exequals((struct Primblock *)yypvt[-2].expval, yypvt[-0].expval); } break; -case 212: -/* # line 978 "gram.in" */ -{ exassign(yypvt[-0].namval, yypvt[-2].labval); } break; -case 215: -/* # line 982 "gram.in" */ -{ inioctl = NO; } break; -case 216: -/* # line 984 "gram.in" */ -{ exarif(yypvt[-6].expval, yypvt[-4].labval, yypvt[-2].labval, yypvt[-0].labval); thiswasbranch = YES; } break; -case 217: -/* # line 986 "gram.in" */ -{ excall(yypvt[-0].namval, LBNULL, 0, labarray); } break; -case 218: -/* # line 988 "gram.in" */ -{ excall(yypvt[-2].namval, LBNULL, 0, labarray); } break; -case 219: -/* # line 990 "gram.in" */ -{ if(nstars < maxlablist) - excall(yypvt[-3].namval, mklist(revchain(yypvt[-1].chval)), nstars, labarray); - else - many("alternate returns", 'l', maxlablist); - } break; -case 220: -/* # line 996 "gram.in" */ -{ exreturn(yypvt[-0].expval); thiswasbranch = YES; } break; -case 221: -/* # line 998 "gram.in" */ -{ exstop(yypvt[-2].ival, yypvt[-0].expval); thiswasbranch = yypvt[-2].ival; } break; -case 222: -/* # line 1002 "gram.in" */ -{ yyval.labval = mklabel( convci(toklen, token) ); } break; -case 223: -/* # line 1006 "gram.in" */ -{ if(parstate == OUTSIDE) - { - newproc(); - startproc(ESNULL, CLMAIN); - } - } break; -case 224: -/* # line 1015 "gram.in" */ -{ exgoto(yypvt[-0].labval); thiswasbranch = YES; } break; -case 225: -/* # line 1017 "gram.in" */ -{ exasgoto(yypvt[-0].namval); thiswasbranch = YES; } break; -case 226: -/* # line 1019 "gram.in" */ -{ exasgoto(yypvt[-4].namval); thiswasbranch = YES; } break; -case 227: -/* # line 1021 "gram.in" */ -{ if(nstars < maxlablist) - putcmgo(putx(fixtype(yypvt[-0].expval)), nstars, labarray); - else - many("labels in computed GOTO list", 'l', maxlablist); - } break; -case 230: -/* # line 1033 "gram.in" */ -{ nstars = 0; yyval.namval = yypvt[-0].namval; } break; -case 231: -/* # line 1037 "gram.in" */ -{ yyval.chval = yypvt[-0].expval ? mkchain((char *)yypvt[-0].expval,CHNULL) : CHNULL; } break; -case 232: -/* # line 1039 "gram.in" */ -{ yyval.chval = yypvt[-0].expval ? mkchain((char *)yypvt[-0].expval, yypvt[-2].chval) : yypvt[-2].chval; } break; -case 234: -/* # line 1044 "gram.in" */ -{ if(nstars < maxlablist) labarray[nstars++] = yypvt[-0].labval; yyval.expval = 0; } break; -case 235: -/* # line 1048 "gram.in" */ -{ yyval.ival = 0; } break; -case 236: -/* # line 1050 "gram.in" */ -{ yyval.ival = 2; } break; -case 237: -/* # line 1054 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, CHNULL); } break; -case 238: -/* # line 1056 "gram.in" */ -{ yyval.chval = hookup(yypvt[-2].chval, mkchain((char *)yypvt[-0].expval,CHNULL) ); } break; -case 239: -/* # line 1060 "gram.in" */ -{ if(parstate == OUTSIDE) - { - newproc(); - startproc(ESNULL, CLMAIN); - } - -/* This next statement depends on the ordering of the state table encoding */ - - if(parstate < INDATA) enddcl(); - } break; -case 240: -/* # line 1073 "gram.in" */ -{ intonly = YES; } break; -case 241: -/* # line 1077 "gram.in" */ -{ intonly = NO; } break; -case 242: -/* # line 1082 "gram.in" */ -{ endio(); } break; -case 244: -/* # line 1087 "gram.in" */ -{ ioclause(IOSUNIT, yypvt[-0].expval); endioctl(); } break; -case 245: -/* # line 1089 "gram.in" */ -{ ioclause(IOSUNIT, ENULL); endioctl(); } break; -case 246: -/* # line 1091 "gram.in" */ -{ ioclause(IOSUNIT, IOSTDERR); endioctl(); } break; -case 248: -/* # line 1094 "gram.in" */ -{ doio(CHNULL); } break; -case 249: -/* # line 1096 "gram.in" */ -{ doio(CHNULL); } break; -case 250: -/* # line 1098 "gram.in" */ -{ doio(revchain(yypvt[-0].chval)); } break; -case 251: -/* # line 1100 "gram.in" */ -{ doio(revchain(yypvt[-0].chval)); } break; -case 252: -/* # line 1102 "gram.in" */ -{ doio(revchain(yypvt[-0].chval)); } break; -case 253: -/* # line 1104 "gram.in" */ -{ doio(CHNULL); } break; -case 254: -/* # line 1106 "gram.in" */ -{ doio(revchain(yypvt[-0].chval)); } break; -case 255: -/* # line 1108 "gram.in" */ -{ doio(CHNULL); } break; -case 256: -/* # line 1110 "gram.in" */ -{ doio(revchain(yypvt[-0].chval)); } break; -case 258: -/* # line 1117 "gram.in" */ -{ iostmt = IOBACKSPACE; } break; -case 259: -/* # line 1119 "gram.in" */ -{ iostmt = IOREWIND; } break; -case 260: -/* # line 1121 "gram.in" */ -{ iostmt = IOENDFILE; } break; -case 262: -/* # line 1128 "gram.in" */ -{ iostmt = IOINQUIRE; } break; -case 263: -/* # line 1130 "gram.in" */ -{ iostmt = IOOPEN; } break; -case 264: -/* # line 1132 "gram.in" */ -{ iostmt = IOCLOSE; } break; -case 265: -/* # line 1136 "gram.in" */ -{ - ioclause(IOSUNIT, ENULL); - ioclause(IOSFMT, yypvt[-0].expval); - endioctl(); - } break; -case 266: -/* # line 1142 "gram.in" */ -{ - ioclause(IOSUNIT, ENULL); - ioclause(IOSFMT, ENULL); - endioctl(); - } break; -case 267: -/* # line 1150 "gram.in" */ -{ - ioclause(IOSUNIT, yypvt[-1].expval); - endioctl(); - } break; -case 268: -/* # line 1155 "gram.in" */ -{ endioctl(); } break; -case 271: -/* # line 1163 "gram.in" */ -{ ioclause(IOSPOSITIONAL, yypvt[-0].expval); } break; -case 272: -/* # line 1165 "gram.in" */ -{ ioclause(IOSPOSITIONAL, ENULL); } break; -case 273: -/* # line 1167 "gram.in" */ -{ ioclause(IOSPOSITIONAL, IOSTDERR); } break; -case 274: -/* # line 1169 "gram.in" */ -{ ioclause(yypvt[-1].ival, yypvt[-0].expval); } break; -case 275: -/* # line 1171 "gram.in" */ -{ ioclause(yypvt[-1].ival, ENULL); } break; -case 276: -/* # line 1173 "gram.in" */ -{ ioclause(yypvt[-1].ival, IOSTDERR); } break; -case 277: -/* # line 1177 "gram.in" */ -{ yyval.ival = iocname(); } break; -case 278: -/* # line 1181 "gram.in" */ -{ iostmt = IOREAD; } break; -case 279: -/* # line 1185 "gram.in" */ -{ iostmt = IOWRITE; } break; -case 280: -/* # line 1189 "gram.in" */ -{ - iostmt = IOWRITE; - ioclause(IOSUNIT, ENULL); - ioclause(IOSFMT, yypvt[-1].expval); - endioctl(); - } break; -case 281: -/* # line 1196 "gram.in" */ -{ - iostmt = IOWRITE; - ioclause(IOSUNIT, ENULL); - ioclause(IOSFMT, ENULL); - endioctl(); - } break; -case 282: -/* # line 1205 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].tagval, CHNULL); } break; -case 283: -/* # line 1207 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].tagval, yypvt[-2].chval); } break; -case 284: -/* # line 1211 "gram.in" */ -{ yyval.tagval = (tagptr) yypvt[-0].expval; } break; -case 285: -/* # line 1213 "gram.in" */ -{ yyval.tagval = (tagptr) mkiodo(yypvt[-1].chval,revchain(yypvt[-3].chval)); } break; -case 286: -/* # line 1217 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, CHNULL); } break; -case 287: -/* # line 1219 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].tagval, CHNULL); } break; -case 289: -/* # line 1224 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, mkchain((char *)yypvt[-2].expval, CHNULL) ); } break; -case 290: -/* # line 1226 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].tagval, mkchain((char *)yypvt[-2].expval, CHNULL) ); } break; -case 291: -/* # line 1228 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, mkchain((char *)yypvt[-2].tagval, CHNULL) ); } break; -case 292: -/* # line 1230 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].tagval, mkchain((char *)yypvt[-2].tagval, CHNULL) ); } break; -case 293: -/* # line 1232 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].expval, yypvt[-2].chval); } break; -case 294: -/* # line 1234 "gram.in" */ -{ yyval.chval = mkchain((char *)yypvt[-0].tagval, yypvt[-2].chval); } break; -case 295: -/* # line 1238 "gram.in" */ -{ yyval.tagval = (tagptr) yypvt[-0].expval; } break; -case 296: -/* # line 1240 "gram.in" */ -{ yyval.tagval = (tagptr) yypvt[-1].expval; } break; -case 297: -/* # line 1242 "gram.in" */ -{ yyval.tagval = (tagptr) mkiodo(yypvt[-1].chval, mkchain((char *)yypvt[-3].expval, CHNULL) ); } break; -case 298: -/* # line 1244 "gram.in" */ -{ yyval.tagval = (tagptr) mkiodo(yypvt[-1].chval, mkchain((char *)yypvt[-3].tagval, CHNULL) ); } break; -case 299: -/* # line 1246 "gram.in" */ -{ yyval.tagval = (tagptr) mkiodo(yypvt[-1].chval, revchain(yypvt[-3].chval)); } break; -case 300: -/* # line 1250 "gram.in" */ -{ startioctl(); } break; - } - goto yystack; /* stack new state and value */ -} diff --git a/usr.bin/f2c/makefile b/usr.bin/f2c/makefile deleted file mode 100644 index d15fe2a..0000000 --- a/usr.bin/f2c/makefile +++ /dev/null @@ -1,90 +0,0 @@ -# Makefile for f2c, a Fortran 77 to C converter - -g = -g -CFLAGS = $g -SHELL = /bin/sh - -OBJECTSd = main.o init.o gram.o lex.o proc.o equiv.o data.o format.o \ - expr.o exec.o intr.o io.o misc.o error.o mem.o names.o \ - output.o p1output.o pread.o put.o putpcc.o vax.o formatdata.o \ - parse_args.o niceprintf.o cds.o sysdep.o version.o -OBJECTS = $(OBJECTSd) malloc.o - -all: xsum.out f2c - -f2c: $(OBJECTS) - $(CC) $(LDFLAGS) $(OBJECTS) -o f2c - -gram.c: gram.head gram.dcl gram.expr gram.exec gram.io defs.h tokdefs.h - ( sed <tokdefs.h "s/#define/%token/" ;\ - cat gram.head gram.dcl gram.expr gram.exec gram.io ) >gram.in - $(YACC) $(YFLAGS) gram.in - echo "(expect 4 shift/reduce)" - sed 's/^# line.*/\/* & *\//' y.tab.c >gram.c - rm -f gram.in y.tab.c - -$(OBJECTSd): defs.h ftypes.h defines.h machdefs.h sysdep.h - -tokdefs.h: tokens - grep -n . <tokens | sed "s/\([^:]*\):\(.*\)/#define \2 \1/" >tokdefs.h - -cds.o: sysdep.h -exec.o: p1defs.h names.h -expr.o: output.h niceprintf.h names.h -format.o: p1defs.h format.h output.h niceprintf.h names.h iob.h -formatdata.o: format.h output.h niceprintf.h names.h -gram.o: p1defs.h -init.o: output.h niceprintf.h iob.h -intr.o: names.h -io.o: names.h iob.h -lex.o : tokdefs.h p1defs.h -main.o: parse.h usignal.h -mem.o: iob.h -names.o: iob.h names.h output.h niceprintf.h -niceprintf.o: defs.h names.h output.h niceprintf.h -output.o: output.h niceprintf.h names.h -p1output.o: p1defs.h output.h niceprintf.h names.h -parse_args.o: parse.h -proc.o: tokdefs.h names.h niceprintf.h output.h p1defs.h -put.o: names.h pccdefs.h p1defs.h -putpcc.o: names.h -vax.o: defs.h output.h pccdefs.h -output.h: niceprintf.h - -put.o putpcc.o: pccdefs.h - -f2c.t: f2c.1t - troff -man f2c.1t >f2c.t - -f2c.1: f2c.1t - nroff -man f2c.1t | col -b | uniq >f2c.1 - -clean: - rm -f gram.c *.o f2c tokdefs.h f2c.t - -b = Notice README cds.c data.c defines.h defs.h equiv.c error.c \ - exec.c expr.c f2c.1 f2c.1t f2c.h format.c format.h formatdata.c \ - ftypes.h gram.dcl gram.exec gram.expr gram.head gram.io \ - init.c intr.c io.c iob.h lex.c machdefs.h main.c makefile \ - malloc.c mem.c memset.c misc.c names.c names.h niceprintf.c \ - niceprintf.h output.c output.h p1defs.h p1output.c \ - parse.h parse_args.c pccdefs.h pread.c proc.c put.c putpcc.c \ - sysdep.c sysdep.h tokens usignal.h vax.c version.c xsum.c - -bundle: - bundle $b xsum0.out >/tmp/f2c.bundle - -xsum: xsum.c - $(CC) -o xsum xsum.c - -#Check validity of transmitted source... -xsum.out: xsum - ./xsum $b >xsum1.out - cmp xsum0.out xsum1.out && mv xsum1.out xsum.out - -#On non-Unix systems that end lines with carriage-return/newline pairs, -#use "make xsumr.out" rather than "make xsum.out". The -r flag ignores -#carriage-return characters. -xsumr.out: xsum - ./xsum -r $b >xsum1.out - cmp xsum0.out xsum1.out && mv xsum1.out xsumr.out diff --git a/usr.bin/f2c/xsum0.out b/usr.bin/f2c/xsum0.out deleted file mode 100644 index 0eecb1c..0000000 --- a/usr.bin/f2c/xsum0.out +++ /dev/null @@ -1,56 +0,0 @@ -Notice 1211689a 1195 -README 110fc3e8 4398 -cds.c 38ec751 4076 -data.c fa8cecd6 9370 -defines.h e500bb1a 8464 -defs.h 72515cc 24172 -equiv.c f6b65bcc 8831 -error.c 7e4ede 3648 -exec.c e279d99 17980 -expr.c 1d64bc48 60705 -f2c.1 fa354030 6042 -f2c.1t e571e717 5988 -f2c.h 1be46b90 4271 -format.c ed4c1a9 52848 -format.h e861ad39 300 -formatdata.c eb45f76a 24861 -ftypes.h 18b86a27 1377 -gram.dcl 11121871 7977 -gram.exec e190cb8e 3026 -gram.expr e3da3320 3137 -gram.head ecf8a5e0 7554 -gram.io 1b7c281c 3294 -init.c ffd3616 11452 -intr.c e9519537 19813 -io.c feb30d5a 29027 -iob.h fe479ed3 459 -lex.c ffae6a9f 31482 -machdefs.h 4950e5b 659 -main.c 54cb955 17040 -makefile f3877062 2766 -malloc.c 5c2be2a 3422 -mem.c 133c066 4839 -memset.c 17404d52 1964 -misc.c fe327633 18006 -names.c 3123927 19947 -names.h f25436a3 689 -niceprintf.c f976e7dd 9781 -niceprintf.h c31f08c 412 -output.c f0627d49 38529 -output.h edfe9e59 2113 -p1defs.h e4e11c4e 5776 -p1output.c 157a2c7e 12175 -parse.h e457df2e 855 -parse_args.c e01b1fe9 13035 -pccdefs.h 1b4fbbee 1195 -pread.c 5ac0d2 16490 -proc.c 116a13d2 34930 -put.c fe8a1281 9480 -putpcc.c 1cebcba8 40081 -sysdep.c 174741bc 10939 -sysdep.h 1021aa5e 2834 -tokens 194fccfe 727 -usignal.h 1c4ce909 124 -vax.c cf2e339 11030 -version.c 3351b7b 107 -xsum.c e2d50e0b 6437 |