home *** CD-ROM | disk | FTP | other *** search
/ Fresh Fish 2 / FFMCD02.bin / new / dev / misc / p2c / src / trans.h < prev   
C/C++ Source or Header  |  1993-12-21  |  79KB  |  1,875 lines

  1. /* "p2c", a Pascal to C translator, version 1.20.
  2.    Copyright (C) 1989, 1990, 1991 Free Software Foundation.
  3.    Author: Dave Gillespie.
  4.    Author's address: daveg@csvax.caltech.edu; 256-80 Caltech/Pasadena CA 91125.
  5.  
  6. This program is free software; you can redistribute it and/or modify
  7. it under the terms of the GNU General Public License as published by
  8. the Free Software Foundation (any version).
  9.  
  10. This program is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13. GNU General Public License for more details.
  14.  
  15. You should have received a copy of the GNU General Public License
  16. along with this program; see the file COPYING.  If not, write to
  17. the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
  18.  
  19.  
  20.  
  21.  
  22. #ifdef __STDC__
  23. # define PP(x)  x             /* use true prototypes */
  24. # define PV()   (void)
  25. # define Anyptr void
  26. # define __CAT__(a,b)a##b
  27. #else
  28. # define PP(x)  ()            /* use old-style declarations */
  29. # define PV()   ()
  30. # define Anyptr char
  31. # define __ID__(a)a
  32. # define __CAT__(a,b)__ID__(a)b
  33. #endif
  34.  
  35. #define Static                /* For debugging purposes */
  36.  
  37.  
  38.  
  39. #include <stdio.h>
  40.  
  41.  
  42. /* If the following heuristic fails, compile -DBSD=0 for non-BSD systems,
  43.    or -DBSD=1 for BSD systems. */
  44.  
  45. #ifdef M_XENIX
  46. # define BSD 0
  47. #endif
  48.  
  49. #ifdef FILE       /* a #define in BSD, a typedef in SYSV (hp-ux, at least) */
  50. # ifndef BSD
  51. #  define BSD 1
  52. # endif
  53. #endif
  54.  
  55. #ifdef BSD
  56. # if !BSD
  57. #  undef BSD
  58. # endif
  59. #endif
  60.  
  61.  
  62. #ifdef __STDC__
  63. # include <stddef.h>
  64. # include <stdlib.h>
  65. # include <limits.h>
  66. #else
  67. # ifndef BSD
  68. #  include <malloc.h>
  69. #  include <memory.h>
  70. #  include <values.h>
  71. # endif
  72. # define EXIT_SUCCESS 0
  73. # define EXIT_FAILURE 1
  74. # define CHAR_BIT 8
  75. # define LONG_MAX (((unsigned long)~0L) >> 1)
  76. # define LONG_MIN (- LONG_MAX - 1)
  77. #endif
  78.  
  79. #ifdef MCH_AMIGA
  80. # undef EXIT_FAILURE
  81. # undef EXIT_SUCCESS
  82. # define EXIT_FAILURE 20
  83. # define EXIT_ERROR   10
  84. # define EXIT_SUCCESS 0
  85. #endif
  86.  
  87.  
  88. #if defined(BSD) && !defined(__STDC__)
  89. # include <strings.h>
  90. # define memcpy(a,b,n) bcopy(b,a,n)
  91. # define memcmp(a,b,n) bcmp(a,b,n)
  92. char *malloc(), *realloc();
  93. #else
  94. # include <string.h>
  95. #endif
  96.  
  97. #include <ctype.h>
  98.  
  99.  
  100. #ifdef __GNUC__      /* Fast, in-line version of strcmp */
  101. # define strcmp(a,b) ({ char *_aa = (a), *_bb = (b); int _diff;  \
  102.             for (;;) {    \
  103.                 if (!*_aa && !*_bb) { _diff = 0; break; }   \
  104.                             if (*_aa++ != *_bb++)    \
  105.                 { _diff = _aa[-1] - _bb[-1]; break; }   \
  106.             } _diff; })
  107. #endif
  108.  
  109.  
  110. #if defined(HASDUMPS) && defined(define_globals)
  111. # define DEFDUMPS
  112. #endif
  113.  
  114.  
  115.  
  116. /* Constants */
  117.  
  118. #undef MININT      /* we want the Pascal definitions, not the local C definitions */
  119. #undef MAXINT
  120.  
  121. #define MININT     0x80000000
  122. #define MAXINT     0x7fffffff
  123.  
  124.  
  125. #ifndef EXIT_SUCCESS
  126. # define EXIT_SUCCESS  0
  127. # define EXIT_FAILURE  1
  128. #endif
  129.  
  130.  
  131. #ifndef P2C_HOME
  132. # ifdef citPWS
  133. #  define    P2C_HOME        "/lib/p2c"
  134. # else
  135. #  define    P2C_HOME        "/usr/local/p2c"     /* sounds reasonable... */
  136. # endif
  137. #endif
  138.  
  139. #ifdef define_globals
  140. char *p2c_home = P2C_HOME;
  141. #else
  142. extern char *p2c_home;
  143. #endif
  144.  
  145. #define P2C_VERSION  "1.20"
  146.  
  147.  
  148.  
  149.  
  150. /* Types */
  151.  
  152. #ifdef __STDC__
  153. typedef void *anyptr;
  154. #else
  155. typedef char *anyptr;
  156. #endif
  157.  
  158. typedef unsigned char uchar;
  159.  
  160.  
  161.  
  162. /* Ought to rearrange token assignments at the next full re-compile */
  163.  
  164. typedef enum E_token {
  165.     TOK_NONE,
  166.  
  167.     /* reserved words */
  168.     TOK_AND, TOK_ARRAY, TOK_BEGIN, TOK_CASE, TOK_CONST,
  169.     TOK_DIV, TOK_DO, TOK_DOWNTO, TOK_ELSE, TOK_END,
  170.     TOK_FILE, TOK_FOR, TOK_FUNCTION, TOK_GOTO, TOK_IF,
  171.     TOK_IN, TOK_LABEL, TOK_MOD, TOK_NIL, TOK_NOT,
  172.     TOK_OF, TOK_OR, TOK_PACKED, TOK_PROCEDURE, TOK_PROGRAM,
  173.     TOK_RECORD, TOK_REPEAT, TOK_SET, TOK_THEN, TOK_TO,
  174.     TOK_TYPE, TOK_UNTIL, TOK_VAR, TOK_WHILE, TOK_WITH,
  175.  
  176.     /* symbols */
  177.     TOK_DOLLAR, TOK_STRLIT, TOK_LPAR, TOK_RPAR, TOK_STAR,
  178.     TOK_PLUS, TOK_COMMA, TOK_MINUS, TOK_DOT, TOK_DOTS,
  179.     TOK_SLASH, TOK_INTLIT, TOK_REALLIT, TOK_COLON, TOK_ASSIGN,
  180.     TOK_SEMI, TOK_NE, TOK_LT, TOK_GT, TOK_LE, TOK_GE,
  181.     TOK_EQ, TOK_LBR, TOK_RBR, TOK_HAT,
  182.     TOK_INCLUDE, TOK_ENDIF,
  183.     TOK_IDENT, TOK_MININT, TOK_EOF,
  184.  
  185.     /* C symbols */
  186.     TOK_ARROW, TOK_AMP, TOK_VBAR, TOK_BANG,
  187.     TOK_TWIDDLE, TOK_PERC, TOK_QM,
  188.     TOK_LTLT, TOK_GTGT, TOK_EQEQ, TOK_BANGEQ,
  189.     TOK_PLPL, TOK_MIMI, TOK_ANDAND, TOK_OROR,
  190.     TOK_LBRACE, TOK_RBRACE, TOK_CHARLIT,
  191.  
  192.     /* HP Pascal tokens */
  193.     TOK_ANYVAR, TOK_EXPORT, TOK_IMPLEMENT, TOK_IMPORT, TOK_MODULE,
  194.     TOK_OTHERWISE, TOK_RECOVER, TOK_TRY,
  195.  
  196.     /* Turbo Pascal tokens */
  197.     TOK_SHL, TOK_SHR, TOK_XOR, TOK_INLINE, TOK_ABSOLUTE,
  198.     TOK_INTERRUPT, TOK_ADDR, TOK_HEXLIT,
  199.  
  200.     /* Oregon Software Pascal tokens */
  201.     TOK_ORIGIN, TOK_INTFONLY,
  202.  
  203.     /* VAX Pascal tokens */
  204.     TOK_REM, TOK_VALUE, TOK_VARYING, TOK_OCTLIT, TOK_COLONCOLON,
  205.     TOK_STARSTAR,
  206.  
  207.     /* Modula-2 tokens */
  208.     TOK_BY, TOK_DEFINITION, TOK_ELSIF, TOK_FROM, TOK_LOOP,
  209.     TOK_POINTER, TOK_QUALIFIED, TOK_RETURN,
  210.  
  211.     /* UCSD Pascal tokens */
  212.     TOK_SEGMENT,
  213.  
  214.     TOK_LAST
  215. } Token;
  216.  
  217. #ifdef define_globals
  218. char *toknames[(int)TOK_LAST] = { "",
  219.     "AND", "ARRAY", "BEGIN", "CASE", "CONST",
  220.     "DIV", "DO", "DOWNTO", "ELSE", "END",
  221.     "FILE", "FOR", "FUNCTION", "GOTO", "IF",
  222.     "IN", "LABEL", "MOD", "NIL", "NOT",
  223.     "OF", "OR", "PACKED", "PROCEDURE", "PROGRAM",
  224.     "RECORD", "REPEAT", "SET", "THEN", "TO",
  225.     "TYPE", "UNTIL", "VAR", "WHILE", "WITH",
  226.  
  227.     "a '$'", "a string literal", "a '('", "a ')'", "a '*'",
  228.     "a '+'", "a comma", "a '-'", "a '.'", "'..'",
  229.     "a '/'", "an integer", "a real number", "a colon", "a ':='",
  230.     "a semicolon", "a '<>'", "a '<'", "a '>'", "a '<='", "a '>='",
  231.     "an '='", "a '['", "a ']'", "a '^'",
  232.     "an \"include\" file", "$end$",
  233.     "an identifier", "an integer", "end of file",
  234.  
  235.     "an '->'", "an '&'", "a '|'", "a '!'", 
  236.     "a '~'", "a '%'", "a '?'",
  237.     "a '<<'", "a '>>'", "a '=='", "a '!='",
  238.     "a '++'", "a '--'", "a '&&'", "a '||'",
  239.     "a '{'", "a '}'", "a character literal",
  240.  
  241.     "ANYVAR", "EXPORT", "IMPLEMENT", "IMPORT", "MODULE",
  242.     "OTHERWISE", "RECOVER", "TRY",
  243.  
  244.     "SHL", "SHR", "XOR", "INLINE", "ABSOLUTE",
  245.     "INTERRUPT", "an '@'", "a hex integer",
  246.  
  247.     "ORIGIN", "INTF-ONLY",
  248.  
  249.     "REM", "VALUE", "VARYING", "an octal integer", "a '::'",
  250.     "a '**'",
  251.  
  252.     "BY", "DEFINITION", "ELSIF", "FROM", "LOOP",
  253.     "POINTER", "QUALIFIED", "RETURN",
  254.  
  255.     "SEGMENT"
  256. } ;
  257. #else
  258. extern char *toknames[];
  259. #endif /*define_globals*/
  260.  
  261. typedef struct S_strlist {
  262.     struct S_strlist *next;
  263.     long value;
  264.     char s[1];
  265. } Strlist;
  266.  
  267.  
  268.  
  269. typedef struct S_value {
  270.     struct S_type *type;
  271.     long i;
  272.     char *s;
  273. } Value;
  274.  
  275.  
  276.  
  277. /* "Symbol" notes:
  278.  *
  279.  * The symbol table is used for several things.  Mainly it records all
  280.  * identifiers in the Pascal program (normally converted to upper case).
  281.  * Also used for recording certain properties about C and Pascal names.
  282.  *
  283.  * The symbol table is a hash table of binary trees.
  284.  */
  285.  
  286. #define AVOIDNAME  0x1         /* Avoid this name in C code */
  287. #define WARNNAME   0x2           /* Warn if using this name in C code */
  288. #define AVOIDGLOB  0x4           /* Avoid C name except private to module */
  289. #define NOSIDEEFF  0x8           /* Function by this name has no side effects */
  290. #define STRUCTF    0x10           /* Function by this name is a StructFunction */
  291. #define STRLAPF    0x20           /* Function by this name is a StrlapFunction */
  292. #define LEAVEALONE 0x40           /* Do not use custom handler for function */
  293. #define DETERMF    0x80           /* Function by this name is Deterministic */
  294. #define FMACREC    0x100       /* Used by FieldMacro stuff */
  295. #define AVOIDFIELD 0x200       /* Avoid this name as a struct field name */
  296. #define NEEDSTATIC 0x400       /* This name must be declared static */
  297. #define KWPOSS     0x800       /* This word may be a keyword */
  298. #define FUNCBREAK  0x7000      /* Line breaking flags (see sys.p2crc) */
  299. # define FALLBREAK  0x1000     /*  Break at all commas if at any */
  300. # define FSPCARG1   0x2000     /*  First argument is special */
  301. # define FSPCARG2   0x3000     /*  First two arguments are special */
  302. # define FSPCARG3   0x4000     /*  First three arguments are special */
  303. #define WARNLIBR   0x8000      /* Warn for all uses of this library function */
  304. #define FWDPARAM   0x10000     /* Was a param name for forward-declared func */
  305. #define SSYNONYM   0x20000     /* Symbol is a synonym for another */
  306.  
  307. typedef struct S_symbol {
  308.     struct S_symbol *left;     /* Left pointer in binary tree */
  309.     struct S_symbol *right;    /* Right pointer in binary tree */
  310.     struct S_meaning *mbase;   /* First normal meaning for this symbol */
  311.     struct S_meaning *fbase;   /* First record-field meaning for this symbol */
  312.     Strlist *symbolnames;      /* List of NameOf's for this name */
  313.     long flags;               /* (above) */
  314.     Token kwtok;           /* Token, if symbol is a keyword */
  315.     char name[1];              /* Pascal name (actually variable-sized) */
  316. } Symbol;
  317.  
  318.  
  319.  
  320. /* "Meaning" notes:
  321.  *
  322.  * This represents one meaning of a symbol (see below).  Meanings are
  323.  * organized in a tree of contexts (i.e., scopes), and also in linked
  324.  * lists of meanings per symbol.  Fields described in the following are
  325.  * undefined for kinds where they are not listed.  Other fields are
  326.  * defined in all kinds of meanings.
  327.  *
  328.  * MK_MODULE:  Program, module, or unit.
  329.  *    mp->anyvarflag = 1 if main program, 0 if module.
  330.  *    mp->cbase => First meaning in module's context.
  331.  *
  332.  * MK_CONST:  Pascal CONST.
  333.  *    mp->type => Type of constant, same as mp->constdefn->type & mp->val.type.
  334.  *    mp->anyvarflag = 1 if FoldConstants was true when defined.
  335.  *    mp->constdefn => Expression for the value of the constant.
  336.  *    mp->val = Value of the const, if can be evaluated, else val.type is NULL.
  337.  *    mp->xnext => Next constant in enumeration, else NULL.
  338.  *    mp->isreturn = 1 if constant was declared as a macro (with #define).
  339.  *
  340.  * MK_TYPE:  Pascal type name.
  341.  *    mp->type => Type which name represents.
  342.  *
  343.  * MK_VAR:  Normal variable.
  344.  *    mp->type => Type of variable.
  345.  *    mp->constdefn => Initializer for variable, else NULL.
  346.  *    mp->varstructflag = 1 if variable is in parent function's varstruct.
  347.  *    mp->isforward = 1 if should be declared static.
  348.  *    mp->isfunction = 1 if should be declared extern.
  349.  *    mp->namedfile = 1 if this file variable has a shadow file-name variable.
  350.  *    mp->bufferedfile = 1 if this file variable has a shadow buffer variable.
  351.  *    mp->val.s => name format string if temporary var, else NULL.
  352.  *
  353.  * MK_VARREF:  Variable always referenced through a pointer.
  354.  *    mp->type => Type "pointer to T" where T is type of variable.
  355.  *    mp->constdefn => Initializer for the pointer, else NULL.
  356.  *    (Others same as for MK_VAR.)
  357.  *
  358.  * MK_VARMAC:  Variable which has a VarMacro.
  359.  *    mp->type => Type of variable.
  360.  *    mp->constdefn => Expression for VarMacro definition.
  361.  *    (Others same as for MK_VAR.)
  362.  *
  363.  * MK_SPVAR:  Special variable.
  364.  *    mp->handler => C function to parse and translate the special variable.
  365.  *
  366.  * MK_FIELD:  Record/struct field name.
  367.  *    mp->ctx, cbase = unused (unlike other meanings).
  368.  *    mp->cnext => Next field in record or variant.
  369.  *    mp->type => Type of field (base type if a bit-field).
  370.  *    mp->rectype => Type of containing record.
  371.  *    mp->constdefn => Expression for definition if FieldMacro, else NULL.
  372.  *    mp->val.i = Number of bits if bit-field, or 0 if normal field.
  373.  *    mp->val.type => True type of bit-field, else same as mp->type.
  374.  *    mp->isforward = 1 if tag field for following variant, else 0.
  375.  *    mp->namedfile = 1 if this file field has a shadow file-name field.
  376.  *    mp->bufferedfile = 1 if this file field has a shadow buffer field.
  377.  *
  378.  * MK_VARIANT:  Header for variant record case.
  379.  *    mp->ctx => First field in variant (unlike other meanings).
  380.  *    mp->cbase = unused (unlike other meanings).
  381.  *    mp->cnext => Next variant in record (or next sub-variant in variant).
  382.  *    mp->rectype => Type of containing record.
  383.  *    mp->val = Tag value of variant.
  384.  *
  385.  * MK_LABEL:  Statement label.
  386.  *    mp->val.i => Case number if used by non-local gotos, else -1.
  387.  *    mp->xnext => MK_VAR representing associated jmp_buf variable.
  388.  *    (All optional fields are unused.)
  389.  *
  390.  * MK_FUNCTION:  Procedure or function.
  391.  *    mp->type => TK_FUNCTION type.
  392.  *    mp->cbase => First meaning in procedure's context (when isfunction is 1,
  393.  *           this will always be the return-value meaning.)
  394.  *    mp->val.i => Body of the function (cast to Stmt *).
  395.  *    mp->constdefn => Expression for definition if FuncMacro, else NULL.
  396.  *    mp->handler => C function to adjust parse tree if predefined, else NULL.
  397.  *    mp->isfunction = 1 if function, 0 if procedure.
  398.  *    mp->isforward = 1 if function has been declared forward.
  399.  *    mp->varstructflag = 1 if function has a varstruct.
  400.  *    mp->needvarstruct = 1 if no varstruct yet but may need one.
  401.  *    mp->namedfile = 1 if function should be declared "inline".
  402.  *
  403.  * MK_SPECIAL:  Special, irregular built-in function.
  404.  *    mp->handler => C function to parse and translate the special function.
  405.  *    mp->constdefn => Expression for definition if FuncMacro, else NULL.
  406.  *    mp->isfunction = 1 if function, 0 if procedure.
  407.  *
  408.  * MK_PARAM:  Procedure or function parameter, or function return value.
  409.  *    mp->type => Type of parameter.
  410.  *    mp->isreturn = 1 if a function return value (not on parameter list).
  411.  *    mp->xnext => Next parameter of function.
  412.  *    mp->fakeparam = 1 if a fake parameter (e.g., conformant array size).
  413.  *    mp->othername => Name of true param if this one is a local copy.
  414.  *    mp->rectype => Type of true param if this one is a local copy.
  415.  *             If a normal copy param, will be "pointer to" mp->type.
  416.  *             If copied for varstruct reasons, will be same as mp->type.
  417.  *    mp->varstructflag = 1 if variable is in parent function's varstruct.
  418.  *
  419.  * MK_VARPARAM:  VAR parameter, or StructFunction return value.
  420.  *    mp->type => Type "pointer to T" where T is type of parameter.
  421.  *    mp->anyvarflag = 1 if no type checking is to be applied to parameter.
  422.  *    mp->isreturn = 1 if a StructFunction return value (will be first param).
  423.  *    (Others same as for MK_PARAM.)
  424.  *
  425.  * MK_VARPARAM with mp->type == tp_anyptr:  Turbo "typeless var" parameter.
  426.  *    mp->type = tp_anyptr.
  427.  *    mp->anyvarflag = 1.
  428.  *    (Others same as for MK_PARAM.)
  429.  *
  430.  * MK_VARPARAM with mp->type == tp_strptr:  HP Pascal "var s:string" parameter.
  431.  *    mp->type = tp_strptr.
  432.  *    mp->anyvarflag = 1 if a separate "strmax" parameter is passed.
  433.  *    (Others same as for MK_PARAM.)
  434.  *
  435.  * MK_SYNONYM:  Meaning which should be treated as identical to another.
  436.  *    mp->xnext => Actual meaning to be used.
  437.  *
  438.  */
  439.  
  440. enum meaningkind {
  441.     MK_NONE, MK_SPECIAL,
  442.     MK_MODULE, MK_FUNCTION, MK_CONST, MK_VAR, MK_TYPE,
  443.     MK_FIELD, MK_LABEL, MK_VARIANT,
  444.     MK_PARAM, MK_VARPARAM, MK_VARREF, MK_VARMAC,
  445.     MK_SPVAR, MK_SYNONYM,
  446.     MK_LAST
  447. } ;
  448.  
  449. #ifdef DEFDUMPS
  450. char *meaningkindnames[(int)MK_LAST] = {
  451.     "MK_NONE", "MK_SPECIAL",
  452.     "MK_MODULE", "MK_FUNCTION", "MK_CONST", "MK_VAR", "MK_TYPE",
  453.     "MK_FIELD", "MK_LABEL", "MK_VARIANT",
  454.     "MK_PARAM", "MK_VARPARAM", "MK_VARREF", "MK_VARMAC",
  455.     "MK_SPVAR", "MK_SYNONYM"
  456. } ;
  457. #endif /*DEFDUMPS*/
  458.  
  459. typedef struct S_meaning {
  460.     struct S_meaning *snext;   /* Next meaning for this symbol */
  461.     struct S_meaning *cnext;   /* Next meaning in this meaning's context */
  462.     struct S_meaning *cbase;   /* First meaning in this context */
  463.     struct S_meaning *ctx;     /* Context of this meaning */
  464.     struct S_meaning *xnext;   /* (above) */
  465.     struct S_meaning *dtype;   /* Declared type name, if any */
  466.     struct S_symbol *sym;      /* Symbol of which this is a meaning */
  467.     struct S_type *type;       /* (above) */
  468.     struct S_type *rectype;    /* (above) */
  469.     struct S_expr *constdefn;  /* (above) */
  470.     enum meaningkind kind;     /* Kind of meaning */
  471.     unsigned needvarstruct:1,  /* (above) */
  472.              varstructflag:1,  /* (above) */
  473.              wasdeclared:1,    /* Declaration has been written for meaning */
  474.              istemporary:1,    /* Is a temporary variable */
  475.              isforward:1,      /* (above) */
  476.              isfunction:1,     /* (above) */
  477.              anyvarflag:1,     /* (above) */
  478.              isactive:1,       /* Meaning is currently in scope */
  479.              exported:1,       /* Meaning is visible outside this module */
  480.              warnifused:1,     /* WarnNames was 1 when meaning was declared */
  481.              dumped:1,           /* Has been dumped (for debugging) */
  482.              isreturn:1,       /* (above) */
  483.              fakeparam:1,      /* (above) */
  484.              namedfile:1,      /* (above) */
  485.              bufferedfile:1,   /* (above) */
  486.              volatilequal:1,   /* Object has C "volatile" qualifier */
  487.              constqual:1,      /* Object has C "const" qualifier */
  488.              dummy17:1, dummy18:1, dummy19:1, 
  489.          dummy20:1, dummy21:1, dummy22:1, dummy23:1, dummy24:1, dummy25:1, 
  490.          dummy26:1, dummy27:1, dummy28:1, dummy29:1, dummy30:1, dummy31:1;
  491.     Value val;               /* (above) */
  492.     int refcount;           /* Number of references to meaning in program */
  493.     char *name;               /* Print name (i.e., C name) of the meaning */
  494.     char *othername;           /* (above) */
  495.     struct S_expr *(*handler)();   /* Custom translator for procedure */
  496.     Strlist *comments;           /* Comments associated with meaning */
  497. } Meaning;
  498.  
  499.  
  500.  
  501. /* "Type" notes:
  502.  *
  503.  * This struct represents a data type.  Types are stored in a strange
  504.  * cross between Pascal and C semantics.  (This usually works out okay.)
  505.  *
  506.  * TK_INTEGER:  Base integer type.
  507.  *    The following types are TK_INTEGER:
  508.  *        tp_integer, tp_unsigned, tp_int, tp_uint, tp_sint.
  509.  *    All other integer types are represented by subranges.
  510.  *    tp->smin => Minimum value for integer.
  511.  *    tp->smax => Maximum value for integer.
  512.  *
  513.  * TK_CHAR:  Base character type.
  514.  *    The following types are TK_CHAR:  tp_char, tp_schar, tp_uchar.
  515.  *    All other character types are represented by subranges.
  516.  *    tp->smin => Minimum value for character.
  517.  *    tp->smax => Maximum value for character.
  518.  *
  519.  * TK_BOOLEAN:  Boolean type.
  520.  *    The only TK_BOOLEAN type is tp_boolean.
  521.  *    tp->smin => "False" expression.
  522.  *    tp->smax => "True" expression.
  523.  *
  524.  * TK_REAL:  Real types.
  525.  *    The only TK_REAL types are tp_real, tp_longreal, and/or the SINGLE type.
  526.  *
  527.  * TK_VOID:  C "void" type.
  528.  *    The only TK_VOID type is tp_void.
  529.  *
  530.  * TK_SUBR:  Subrange of ordinal type.
  531.  *    tp->basetype => a TK_INTEGER, TK_CHAR, TK_BOOLEAN, or TK_ENUM type.
  532.  *    tp->smin => Minimum ordinal value for subrange.
  533.  *    tp->smax => Maximum ordinal value for subrange.
  534.  *
  535.  * TK_ENUM:  Enumerated type.
  536.  *    tp->fbase => First enumeration constant.
  537.  *    tp->smin => Minimum value (zero).
  538.  *    tp->smax => Maximum value (number of choices minus 1).
  539.  *
  540.  * TK_POINTER:  Pointer type.
  541.  *    tp->basetype => Base type of pointer.
  542.  *    tp->smin => EK_NAME for type if not-yet-resolved forward; else NULL.
  543.  *    tp->fbase => Actual type name for tp->basetype, or NULL.
  544.  *    Only one pointer type is ever generated for a given other type;
  545.  *    each tp->pointertype points back to that type if it has been generated.
  546.  *
  547.  * TK_STRING:  Pascal string or VARYING OF CHAR type.
  548.  *    tp->basetype => tp_char.
  549.  *    tp->indextype => TK_SUBR from 0 to maximum string length.
  550.  *    tp->structdefd = 1 if type is for a conformant VARYING OF CHAR parameter.
  551.  *
  552.  * TK_RECORD:  Pascal record/C struct type.
  553.  *    tp->fbase => First field in record.
  554.  *    tp->structdefd = 1 if struct type has been declared in output.
  555.  *
  556.  * TK_ARRAY with smax == NULL:  Normal array type.
  557.  *    tp->basetype => Element type of array.
  558.  *    tp->indextype => Index type (usually a TK_SUBR).
  559.  *    tp->smin => Integer constant if SkipIndices was used, else NULL.
  560.  *    tp->smax = NULL.
  561.  *    tp->structdefd = 1 if type is for a conformant array parameter.
  562.  *    tp->fbase => Actual type name for tp->basetype, or NULL.
  563.  *
  564.  * TK_ARRAY with smax != NULL:  Large packed array type.
  565.  *    tp->basetype => Element type of C array (tp_ubyte/tp_sbyte/tp_sshort).
  566.  *    tp->indextype => Index type (usually a TK_SUBR).
  567.  *    tp->smin => Integer constant if SkipIndices was used, else NULL.
  568.  *    tp->smax => EK_TYPENAME for element type of Pascal array.
  569.  *    tp->escale = log-base-two of number of bits per packed element, else 0.
  570.  *    tp->issigned = 1 if packed array elements are signed, 0 if unsigned.
  571.  *    tp->structdefd = 1 if type is for a conformant array parameter.
  572.  *    tp->fbase => Actual type name for tp->basetype, or NULL.
  573.  *
  574.  * TK_SMALLARRAY:  Packed array fitting within a single integer.
  575.  *    (Same as for packed TK_ARRAY.)
  576.  *
  577.  * TK_SET:  Normal set type.
  578.  *    tp->basetype => tp_integer.
  579.  *    tp->indextype => Element type of the set.
  580.  *
  581.  * TK_SMALLSET:  Set fitting within a single integer.
  582.  *    (Same as for TK_SET.)
  583.  *
  584.  * TK_FILE:  File type (corresponds to C "FILE" type).
  585.  *    tp->basetype => Type of file elements, or tp_abyte if UCSD untyped file.
  586.  *    A Pascal "file" variable is represented as a TK_POINTER to a TK_FILE.
  587.  *
  588.  * TK_BIGFILE:  File type with attached buffers and name.
  589.  *    tp->basetype => Type of file elements, or tp_abyte if UCSD untyped file.
  590.  *    A Pascal "file" variable is represented directly as a TK_BIGFILE.
  591.  *
  592.  * TK_FUNCTION:  Procedure or procedure-pointer type.
  593.  *    tp->basetype => Return type of function, or tp_void if procedure.
  594.  *    tp->issigned = 1 if type has a generic static link.
  595.  *    tp->fbase => First argument (or StructFunction return buffer pointer).
  596.  *
  597.  * TK_PROCPTR:  Procedure pointer with static link.
  598.  *    tp->basetype => TK_FUNCTION type.
  599.  *    tp->fbase => Internal Meaning struct associated with basetype.
  600.  *    tp->escale = Value of StaticLinks when type was declared.
  601.  *
  602.  * TK_CPROCPTR:  Procedure pointer without static link.
  603.  *    tp->basetype => TK_FUNCTION type.
  604.  *    tp->fbase => Internal Meaning struct associated with basetype.
  605.  *    tp->escale = Value of StaticLinks = 0.
  606.  *
  607.  * TK_SPECIAL:  Special strange data type.
  608.  *    Only TK_SPECIAL type at present is tp_jmp_buf.
  609.  *
  610.  */
  611.  
  612. enum typekind {
  613.     TK_NONE,
  614.     TK_INTEGER, TK_CHAR, TK_BOOLEAN, TK_REAL, TK_VOID,
  615.     TK_SUBR, TK_ENUM, TK_POINTER, TK_STRING,
  616.     TK_RECORD, TK_ARRAY, TK_SET, TK_FILE, TK_FUNCTION,
  617.     TK_PROCPTR, TK_SMALLSET, TK_SMALLARRAY, TK_CPROCPTR,
  618.     TK_SPECIAL, TK_BIGFILE,
  619.     TK_LAST
  620. } ;
  621.  
  622. #ifdef DEFDUMPS
  623. char *typekindnames[(int)TK_LAST] = {
  624.     "TK_NONE",
  625.     "TK_INTEGER", "TK_CHAR", "TK_BOOLEAN", "TK_REAL", "TK_VOID",
  626.     "TK_SUBR", "TK_ENUM", "TK_POINTER", "TK_STRING",
  627.     "TK_RECORD", "TK_ARRAY", "TK_SET", "TK_FILE", "TK_FUNCTION",
  628.     "TK_PROCPTR", "TK_SMALLSET", "TK_SMALLARRAY", "TK_CPROCPTR",
  629.     "TK_SPECIAL", "TK_BIGFILE"
  630. } ;
  631. #endif /*DEFDUMPS*/
  632.  
  633. typedef struct S_type {
  634.     enum typekind kind;        /* Kind of type */
  635.     struct S_type *basetype;   /* (above) */
  636.     struct S_type *indextype;  /* (above) */
  637.     struct S_type *pointertype; /* Pointer to this type */
  638.     struct S_meaning *meaning; /* Name of this type, if any */
  639.     struct S_meaning *fbase;   /* (above) */
  640.     struct S_expr *smin;       /* (above) */
  641.     struct S_expr *smax;       /* (above) */
  642.     unsigned issigned:1,       /* (above) */
  643.              dumped:1,         /* Has been dumped (for debugging) */
  644.              structdefd:1,     /* (above) */
  645.              preserved:1;      /* Declared with preservetypes = 1 */
  646.     short escale;              /* (above) */
  647. } Type;
  648.  
  649.  
  650. /* "Expr" notes:
  651.  *
  652.  * Expression trees generally reflect C notation and semantics.  For example,
  653.  * EK_ASSIGN is not generated for string arguments; these would get an
  654.  * EK_BICALL to strcpy instead.
  655.  *
  656.  * The data type of each expression node is stored in its "val.type" field.
  657.  * The rest of the "val" field is used only when shown below.
  658.  * The "nargs" field always contains the number of arguments; the "args"
  659.  * array is allocated to that size and will contain non-NULL Expr pointers.
  660.  *
  661.  * EK_EQ, EK_NE, EK_LT, EK_GT, EK_LE, EK_GE:  Relational operators.
  662.  *    ep->nargs = 2.
  663.  *
  664.  * EK_PLUS:  Addition.
  665.  *    ep->nargs >= 2.
  666.  *
  667.  * EK_NEG:  Negation.
  668.  *    ep->nargs = 1.
  669.  *
  670.  * EK_TIMES:  Multiplication.
  671.  *    ep->nargs >= 2.
  672.  *
  673.  * EK_DIVIDE:  Real division.
  674.  *    ep->nargs = 2.
  675.  *
  676.  * EK_DIV:  Integer division.
  677.  *    ep->nargs = 2.
  678.  *
  679.  * EK_MOD:  Integer modulo (C "%" operator).
  680.  *    ep->nargs = 2.
  681.  *
  682.  * EK_OR, EK_AND:  Logical operators (C "&&" and "||").
  683.  *    ep->nargs = 2.
  684.  *
  685.  * EK_NOT:  Logical NOT (C "!" operator).
  686.  *    ep->nargs = 1.
  687.  *
  688.  * EK_BAND, EK_BOR, EK_BXOR:  Bitwise operators (C "&", "|", "^").
  689.  *    ep->nargs = 2.
  690.  *
  691.  * EK_BNOT:  Bitwise NOT (C "~" operator).
  692.  *    ep->nargs = 1.
  693.  *
  694.  * EK_LSH, EK_RSH:  Shift operators.
  695.  *    ep->nargs = 2.
  696.  *
  697.  * EK_HAT:  Pointer dereference.
  698.  *    ep->nargs = 1.
  699.  *
  700.  * EK_INDEX:  Array indexing.
  701.  *    ep->nargs = 2.
  702.  *
  703.  * EK_CAST:  "Soft" type cast, change data type retaining value.
  704.  *    ep->type => New data type.
  705.  *    ep->nargs = 1.
  706.  *
  707.  * EK_ACTCAST:  "Active" type cast, performs a computation as result of cast.
  708.  *    ep->type => New data type.
  709.  *    ep->nargs = 1.
  710.  *
  711.  * EK_LITCAST:  Literal type cast.
  712.  *    ep->nargs = 2.
  713.  *    ep->args[0] => EK_TYPENAME expression for name of new data type.
  714.  *    ep->args[1] => Argument of cast.
  715.  *
  716.  * EK_DOT:  Struct field extraction.
  717.  *    ep->nargs = 1.  (Only one of the following will be nonzero:)
  718.  *    ep->val.i => MK_FIELD being extracted (cast to Meaning *), else 0.
  719.  *    ep->val.s => Literal name of field being extracted, else NULL.
  720.  *
  721.  * EK_COND:  C conditional expression.
  722.  *    ep->nargs = 3.
  723.  *    ep->args[0] => Condition expression.
  724.  *    ep->args[1] => "Then" expression.
  725.  *    ep->args[2] => "Else" expression.
  726.  *
  727.  * EK_ADDR:  Address-of operator.
  728.  *    ep->nargs = 1.
  729.  *
  730.  * EK_SIZEOF:  Size-of operator.
  731.  *    ep->nargs = 1.
  732.  *    ep->args[0] => Argument expression, may be EK_TYPENAME.
  733.  *
  734.  * EK_CONST:  Literal constant.
  735.  *    ep->nargs = 0 or 1.
  736.  *    ep->val = Value of constant.
  737.  *    ep->args[0] => EK_NAME of printf format string for constant, if any.
  738.  *
  739.  * EK_LONGCONST:  Literal constant, type "long int".
  740.  *    (Same as for EK_CONST.)
  741.  *
  742.  * EK_VAR:  Variable name.
  743.  *    ep->nargs = 0.
  744.  *    ep->val.i => Variable being referenced (cast to Meaning *).
  745.  *
  746.  * EK_ASSIGN:  Assignment operator.
  747.  *    ep->nargs = 2.
  748.  *    ep->args[0] => Destination l-value expression.
  749.  *    ep->args[1] => Source expression.
  750.  *
  751.  * EK_POSTINC, EK_POSTDEC:  Post-increment/post-decrement operators.
  752.  *    ep->nargs = 1.
  753.  *
  754.  * EK_MACARG:  Placeholder for argument in expression for FuncMacro, etc.
  755.  *    ep->nargs = 0.
  756.  *    ep->val.i = Code selecting which argument.
  757.  *
  758.  * EK_CHECKNIL:  Null-pointer check.
  759.  *    ep->nargs = 1.
  760.  *
  761.  * EK_BICALL:  Call to literal function name.
  762.  *    ep->val.s => Name of function.
  763.  *
  764.  * EK_STRUCTCONST:  Structured constant.
  765.  *    ep->nargs = Number of elements in constant.
  766.  *    (Note:  constdefn points to an EK_CONST whose val.i points to this.)
  767.  *
  768.  * EK_STRUCTOF:  Repeated element in structured constant.
  769.  *    ep->nargs = 1.
  770.  *    ep->val.i = Number of repetitions.
  771.  *
  772.  * EK_COMMA:  C comma operator.
  773.  *    ep->nargs >= 2.
  774.  *
  775.  * EK_NAME:  Literal variable name.
  776.  *    ep->nargs = 0.
  777.  *    ep->val.s => Name of variable.
  778.  *
  779.  * EK_CTX:  Name of a context, with static links.
  780.  *    ep->nargs = 0.
  781.  *    ep->val.i => MK_FUNCTION or MK_MODULE to name (cast to Meaning *).
  782.  *
  783.  * EK_SPCALL:  Special function call.
  784.  *    ep->nargs = 1 + number of arguments to function.
  785.  *    ep->args[0] => Expression which is the function to call.
  786.  *
  787.  * EK_TYPENAME:  Type name.
  788.  *    ep->nargs = 0.
  789.  *    ep->val.type => Type whose name should be printed.
  790.  *
  791.  * EK_FUNCTION:  Normal function call.
  792.  *    ep->val.i => MK_FUNCTION being called (cast to Meaning *).
  793.  *
  794.  */
  795.  
  796. enum exprkind {
  797.     EK_EQ, EK_NE, EK_LT, EK_GT, EK_LE, EK_GE,
  798.     EK_PLUS, EK_NEG, EK_TIMES, EK_DIVIDE,
  799.     EK_DIV, EK_MOD,
  800.     EK_OR, EK_AND, EK_NOT,
  801.     EK_BAND, EK_BOR, EK_BXOR, EK_BNOT, EK_LSH, EK_RSH,
  802.     EK_HAT, EK_INDEX, EK_CAST, EK_DOT, EK_COND,
  803.     EK_ADDR, EK_SIZEOF, EK_ACTCAST,
  804.     EK_CONST, EK_VAR, EK_FUNCTION,
  805.     EK_ASSIGN, EK_POSTINC, EK_POSTDEC, EK_CHECKNIL,
  806.     EK_MACARG, EK_BICALL, EK_STRUCTCONST, EK_STRUCTOF,
  807.     EK_COMMA, EK_LONGCONST, EK_NAME, EK_CTX, EK_SPCALL,
  808.     EK_LITCAST, EK_TYPENAME,
  809.     EK_LAST
  810. } ;
  811.  
  812. #ifdef DEFDUMPS
  813. char *exprkindnames[(int)EK_LAST] = {
  814.     "EK_EQ", "EK_NE", "EK_LT", "EK_GT", "EK_LE", "EK_GE",
  815.     "EK_PLUS", "EK_NEG", "EK_TIMES", "EK_DIVIDE",
  816.     "EK_DIV", "EK_MOD",
  817.     "EK_OR", "EK_AND", "EK_NOT",
  818.     "EK_BAND", "EK_BOR", "EK_BXOR", "EK_BNOT", "EK_LSH", "EK_RSH",
  819.     "EK_HAT", "EK_INDEX", "EK_CAST", "EK_DOT", "EK_COND",
  820.     "EK_ADDR", "EK_SIZEOF", "EK_ACTCAST",
  821.     "EK_CONST", "EK_VAR", "EK_FUNCTION",
  822.     "EK_ASSIGN", "EK_POSTINC", "EK_POSTDEC", "EK_CHECKNIL",
  823.     "EK_MACARG", "EK_BICALL", "EK_STRUCTCONST", "EK_STRUCTOF",
  824.     "EK_COMMA", "EK_LONGCONST", "EK_NAME", "EK_CTX", "EK_SPCALL",
  825.     "EK_LITCAST", "EK_TYPENAME"
  826. } ;
  827. #endif /*DEFDUMPS*/
  828.  
  829. typedef struct S_expr {
  830.     enum exprkind kind;
  831.     short nargs;
  832.     Value val;
  833.     struct S_expr *args[1];    /* (Actually, variable-sized) */
  834. } Expr;
  835.  
  836.  
  837.  
  838. /* "Stmt" notes.
  839.  *
  840.  * Statements form linked lists along the "next" pointers.
  841.  * All other pointers are NULL and unused unless shown below.
  842.  *
  843.  * SK_ASSIGN:  Assignment or function call (C expression statement).
  844.  *    sp->exp1 => Expression to be evaluated.
  845.  *
  846.  * SK_RETURN:  C "return" statement.
  847.  *    sp->exp1 => Value to return, else NULL.
  848.  *
  849.  * SK_CASE:  C "switch" statement.
  850.  *    sp->exp1 => Switch selector expression.
  851.  *    sp->stm1 => List of SK_CASELABEL statements, followed by list of
  852.  *          statements that make up the "default:" clause.
  853.  *
  854.  * SK_CASELABEL:  C "case" label.
  855.  *    sp->exp1 => Case value.
  856.  *    sp->stm1 => List of SK_CASELABELs labelling the same clause, followed
  857.  *                by list of statements in that clause.
  858.  *
  859.  * SK_CASECHECK:  Case-value-range-error, occurs in "default:" clause.
  860.  *
  861.  * SK_IF:  C "if" statement.
  862.  *    sp->exp1 => Conditional expression.
  863.  *    sp->exp2 => Constant expression, "1" if this "if" should be else-if'd
  864.  *          on to parent "if".  NULL => follow ElseIf parameter.
  865.  *    sp->stm1 => "Then" clause.
  866.  *    sp->stm2 => "Else" clause.
  867.  *
  868.  * SK_FOR:  C "for" statement.
  869.  *    sp->exp1 => Initialization expression (may be NULL).
  870.  *    sp->exp2 => Conditional expression (may be NULL).
  871.  *    sp->exp3 => Iteration expression (may be NULL).
  872.  *    sp->stm1 => Loop body.
  873.  *
  874.  * SK_REPEAT:  C "do-while" statement.
  875.  *    sp->exp1 => Conditional expression (True = continue loop).
  876.  *    sp->stm1 => Loop body.
  877.  *
  878.  * SK_WHILE:  C "while" statement.
  879.  *    sp->exp1 => Conditional expression.
  880.  *    sp->stm1 => Loop body.
  881.  *
  882.  * SK_BREAK:  C "break" statement.
  883.  *
  884.  * SK_CONTINUE:  C "continue" statement.
  885.  *
  886.  * SK_TRY:  HP Pascal TRY-RECOVER statement.
  887.  *    sp->exp1->val.i = Global serial number of the TRY statement.
  888.  *    sp->exp2 = Non-NULL if must generate a label for RECOVER block.
  889.  *    sp->stm1 => TRY block.
  890.  *    sp->stm2 => RECOVER block.
  891.  *
  892.  * SK_GOTO:  C "goto" statement.
  893.  *    sp->exp1 => EK_NAME for the label number or name.
  894.  *
  895.  * SK_LABEL:  C statement label.
  896.  *    sp->exp1 => EK_NAME for the label number of name.
  897.  *
  898.  * SK_HEADER:  Function/module header.
  899.  *    sp->exp1 => EK_VAR pointing to MK_FUNCTION or MK_MODULE.
  900.  *    (This always comes first in a context's statement list.)
  901.  *
  902.  * SK_BODY:  Body of function/module.
  903.  *    sp->stm1 => SK_HEADER that begins the body.
  904.  *    (This exists only during fixblock.)
  905.  *
  906.  */
  907.  
  908. enum stmtkind {
  909.     SK_ASSIGN, SK_RETURN,
  910.     SK_CASE, SK_CASELABEL, SK_IF,
  911.     SK_FOR, SK_REPEAT, SK_WHILE, SK_BREAK, SK_CONTINUE,
  912.     SK_TRY, SK_GOTO, SK_LABEL,
  913.     SK_HEADER, SK_CASECHECK, SK_BODY,
  914.     SK_LAST
  915. } ;
  916.  
  917. #ifdef DEFDUMPS
  918. char *stmtkindnames[(int)SK_LAST] = {
  919.     "SK_ASSIGN", "SK_RETURN",
  920.     "SK_CASE", "SK_CASELABEL", "SK_IF",
  921.     "SK_FOR", "SK_REPEAT", "SK_WHILE", "SK_BREAK", "SK_CONTINUE",
  922.     "SK_TRY", "SK_GOTO", "SK_LABEL",
  923.     "SK_HEADER", "SK_CASECHECK", "SK_BODY"
  924. } ;
  925. #endif /*DEFDUMPS*/
  926.  
  927. typedef struct S_stmt {
  928.     enum stmtkind kind;
  929.     struct S_stmt *next, *stm1, *stm2;
  930.     struct S_expr *exp1, *exp2, *exp3;
  931.     long serial;
  932. } Stmt;
  933.  
  934.  
  935.  
  936. /* Flags for out_declarator(): */
  937.  
  938. #define ODECL_CHARSTAR      0x1
  939. #define ODECL_FREEARRAY     0x2
  940. #define ODECL_FUNCTION      0x4
  941. #define ODECL_HEADER        0x8
  942. #define ODECL_FORWARD       0x10
  943. #define ODECL_DECL        0x20
  944. #define ODECL_NOPRES        0x40
  945.  
  946.  
  947. /* Flags for fixexpr(): */
  948.  
  949. #define ENV_EXPR    0       /* return value needed */
  950. #define ENV_STMT    1       /* return value ignored */
  951. #define ENV_BOOL    2       /* boolean return value needed */
  952.  
  953.  
  954. /* Flags for defmacro(): */
  955. #define MAC_VAR     0       /* VarMacro */
  956. #define MAC_CONST   1       /* ConstMacro */
  957. #define MAC_FIELD   2       /* FieldMacro */
  958. #define MAC_FUNC    3       /* FuncMacro */
  959.  
  960. #define FMACRECname  "<rec>"
  961.  
  962.  
  963. /* Kinds of comment lines: */
  964. #define CMT_SHIFT   24
  965. #define CMT_MASK    ((1L<<CMT_SHIFT)-1)
  966. #define CMT_KMASK   ((1<<(32-CMT_SHIFT))-1)
  967. #define CMT_DONE    0       /* comment that has already been printed */
  968. #define CMT_PRE     1       /* comment line preceding subject */
  969. #define CMT_POST    2       /* comment line following subject */
  970. #define CMT_TRAIL   4       /* comment at end of line of code */
  971. #define CMT_ONBEGIN 6       /* comment on "begin" of procedure */
  972. #define CMT_ONEND   7       /* comment on "end" of procedure */
  973. #define CMT_ONELSE  8       /* comment on "else" keyword */
  974. #define CMT_NOT     256     /* negation of above, for searches */
  975.  
  976. #ifdef define_globals
  977. char *CMT_NAMES[] = { "DONE", "PRE", "POST", "3", "TRAIL", "5",
  978.                       "BEGIN", "END", "ELSE" };
  979. #else
  980. extern char *CMT_NAMES[];
  981. #endif
  982.  
  983. #define getcommentkind(cmt)  (((cmt)->value >> CMT_SHIFT) & CMT_KMASK)
  984.  
  985.  
  986. /* Kinds of operator line-breaking: */
  987. #define BRK_LEFT     0x1
  988. #define BRK_RIGHT    0x2
  989. #define BRK_LPREF    0x4
  990. #define BRK_RPREF    0x8
  991. #define BRK_ALLNONE  0x10
  992. #define BRK_HANG     0x20
  993.  
  994.  
  995.  
  996.  
  997. /* Translation parameters: */
  998.  
  999. #ifdef define_parameters
  1000. # define extern
  1001. #endif /* define_parameters */
  1002.  
  1003. extern enum {
  1004.     UNIX_ANY, UNIX_BSD, UNIX_SYSV
  1005. } which_unix;
  1006.  
  1007. extern enum {
  1008.     LANG_HP, LANG_UCSD, LANG_TURBO, LANG_OREGON, LANG_VAX,
  1009.     LANG_MODULA, LANG_MPW, LANG_BERK
  1010. } which_lang;
  1011.  
  1012. extern short debug, tokentrace, quietmode, cmtdebug, copysource;
  1013. extern int nobanner, showprogress, maxerrors;
  1014. extern short hpux_lang, integer16, doublereals, pascalenumsize;
  1015. extern short needsignedbyte, unsignedchar, importall;
  1016. extern short nestedcomments, pascalsignif, pascalcasesens;
  1017. extern short dollar_idents, ignorenonalpha, modula2;
  1018. extern short ansiC, cplus, signedchars, signedfield, signedshift;
  1019. extern short hassignedchar, voidstar, symcase, ucconsts, csignif;
  1020. extern short copystructs, usevextern, implementationmodules;
  1021. extern short useAnyptrMacros, usePPMacros;
  1022. extern short sprintf_value;
  1023. extern char codefnfmt[40], modulefnfmt[40], logfnfmt[40];
  1024. extern char headerfnfmt[40], headerfnfmt2[40], includefnfmt[40];
  1025. extern char selfincludefmt[40];
  1026. extern char constformat[40], moduleformat[40], functionformat[40];
  1027. extern char varformat[40], fieldformat[40], typeformat[40];
  1028. extern char enumformat[40], symbolformat[40];
  1029. extern char p2c_h_name[40], exportsymbol[40], export_symbol[40];
  1030. extern char externalias[40];
  1031. extern char memcpyname[40], sprintfname[40];
  1032. extern char roundname[40], divname[40], modname[40], remname[40];
  1033. extern char strposname[40], strcicmpname[40];
  1034. extern char strsubname[40], strdeletename[40], strinsertname[40];
  1035. extern char strmovename[40], strpadname[40];
  1036. extern char strltrimname[40], strrtrimname[40], strrptname[40];
  1037. extern char absname[40], oddname[40], evenname[40], swapname[40];
  1038. extern char mallocname[40], freename[40], freervaluename[40];
  1039. extern char randrealname[40], randintname[40], randomizename[40];
  1040. extern char skipspacename[40], readlnname[40], freopenname[40];
  1041. extern char eofname[40], eolnname[40], fileposname[40], maxposname[40];
  1042. extern char setunionname[40], setintname[40], setdiffname[40];
  1043. extern char setinname[40], setaddname[40], setaddrangename[40];
  1044. extern char setremname[40];
  1045. extern char setequalname[40], subsetname[40], setxorname[40];
  1046. extern char setcopyname[40], setexpandname[40], setpackname[40];
  1047. extern char getbitsname[40], clrbitsname[40], putbitsname[40];
  1048. extern char declbufname[40], declbufncname[40];
  1049. extern char resetbufname[40], setupbufname[40];
  1050. extern char getfbufname[40], chargetfbufname[40], arraygetfbufname[40];
  1051. extern char putfbufname[40], charputfbufname[40], arrayputfbufname[40];
  1052. extern char getname[40], chargetname[40], arraygetname[40];
  1053. extern char putname[40], charputname[40], arrayputname[40];
  1054. extern char eofbufname[40], fileposbufname[40];
  1055. extern char storebitsname[40], signextname[40];
  1056. extern char filenotfoundname[40], filenotopenname[40];
  1057. extern char filewriteerrorname[40], badinputformatname[40], endoffilename[40];
  1058. extern short strcpyleft;
  1059. extern char language[40], target[40];
  1060. extern int sizeof_char, sizeof_short, sizeof_integer, sizeof_pointer, 
  1061.            sizeof_double, sizeof_float, sizeof_enum, sizeof_int, sizeof_long;
  1062. extern short size_t_long;
  1063. extern int setbits, defaultsetsize, seek_base, integerwidth, realwidth;
  1064. extern short quoteincludes, expandincludes, collectnest;
  1065. extern int phystabsize, intabsize, linewidth, maxlinewidth;
  1066. extern int majorspace, minorspace, functionspace, minfuncspace;
  1067. extern int casespacing, caselimit;
  1068. extern int returnlimit, breaklimit, continuelimit;
  1069. extern short nullstmtline, shortcircuit, shortopt, usecommas, elseif;
  1070. extern short usereturns, usebreaks, infloopstyle, reusefieldnames;
  1071. extern short bracesalways, braceline, bracecombine, braceelse, braceelseline;
  1072. extern short newlinefunctions;
  1073. extern short eatcomments, spitcomments, spitorphancomments;
  1074. extern short commentafter, blankafter;
  1075. extern int tabsize, blockindent, bodyindent, argindent;
  1076. extern int switchindent, caseindent, labelindent;
  1077. extern int openbraceindent, closebraceindent;
  1078. extern int funcopenindent, funccloseindent;
  1079. extern int structindent, structinitindent, extrainitindent;
  1080. extern int constindent, commentindent, bracecommentindent, commentoverindent;
  1081. extern int declcommentindent;
  1082. extern int minspacing, minspacingthresh;
  1083. extern int extraindent, bumpindent;
  1084. extern double overwidepenalty, overwideextrapenalty;
  1085. extern double commabreakpenalty, commabreakextrapenalty;
  1086. extern double assignbreakpenalty, assignbreakextrapenalty;
  1087. extern double specialargbreakpenalty;
  1088. extern double opbreakpenalty, opbreakextrapenalty, exhyphenpenalty;
  1089. extern double logbreakpenalty, logbreakextrapenalty;
  1090. extern double relbreakpenalty, relbreakextrapenalty;
  1091. extern double morebreakpenalty, morebreakextrapenalty;
  1092. extern double parenbreakpenalty, parenbreakextrapenalty;
  1093. extern double qmarkbreakpenalty, qmarkbreakextrapenalty;
  1094. extern double wrongsidepenalty, earlybreakpenalty, extraindentpenalty;
  1095. extern double bumpindentpenalty, nobumpindentpenalty;
  1096. extern double indentamountpenalty, sameindentpenalty;
  1097. extern double showbadlimit;
  1098. extern long maxalts;
  1099. extern short breakbeforearith, breakbeforerel, breakbeforelog;
  1100. extern short breakbeforedot, breakbeforeassign;
  1101. extern short for_allornone;
  1102. extern short extraparens, breakparens, returnparens;
  1103. extern short variablearrays, initpacstrings, stararrays;
  1104. extern short spaceexprs, spacefuncs, spacecommas, implicitzero, starindex;
  1105. extern int casetabs;
  1106. extern short starfunctions, mixfields, alloczeronil, postincrement;
  1107. extern short mixvars, mixtypes, mixinits, nullcharconst, castnull, addindex;
  1108. extern short highcharints, highcharbits, hasstaticlinks;
  1109. extern short mainlocals, storefilenames, addrstdfiles, readwriteopen;
  1110. extern short charfiletext, messagestderr, literalfilesflag, structfilesflag;
  1111. extern short printfonly, mixwritelns, usegets, newlinespace, binarymode;
  1112. extern char openmode[40], filenamefilter[40];
  1113. extern short atan2flag, div_po2, mod_po2, assumebits, assumesigns;
  1114. extern short fullstrwrite, fullstrread, whilefgets, buildreads, buildwrites;
  1115. extern short foldconsts, foldstrconsts, charconsts, useconsts, useundef;
  1116. extern short elimdeadcode, offsetforloops, forevalorder;
  1117. extern short smallsetconst, bigsetconst, lelerange, unsignedtrick;
  1118. extern short useisalpha, useisspace, usestrncmp;
  1119. extern short casecheck, arraycheck, rangecheck, nilcheck, malloccheck;
  1120. extern short checkfileopen, checkfileisopen, checkfilewrite;
  1121. extern short checkreadformat, checkfileeof, checkstdineof, checkfileseek;
  1122. extern short squeezesubr, useenum, enumbyte, packing, packsigned, keepnulls;
  1123. extern short compenums, formatstrings, alwayscopyvalues;
  1124. extern short use_static, var_static, void_args, prototypes, fullprototyping;
  1125. extern short procptrprototypes, promote_enums;
  1126. extern short preservetypes, preservepointers, preservestrings;
  1127. extern short castargs, castlongargs, promoteargs, fixpromotedargs;
  1128. extern short varstrings, varfiles, copystructfuncs;
  1129. extern long skipindices;
  1130. extern short stringleaders;
  1131. extern int stringceiling, stringdefault, stringtrunclimit, longstringsize;
  1132. extern short warnnames, warnmacros;
  1133. extern Strlist *importfrom, *importdirs, *includedirs, *includefrom;
  1134. extern Strlist *librfiles, *bufferedfiles, *unbufferedfiles;
  1135. extern Strlist *externwords, *cexternwords;
  1136. extern Strlist *varmacros, *constmacros, *fieldmacros;
  1137. extern Strlist *funcmacros, *funcmacroargs, *nameoflist;
  1138. extern Strlist *specialmallocs, *specialfrees, *specialsizeofs;
  1139. extern Strlist *initialcalls, *eatnotes, *literalfiles, *structfiles;
  1140.  
  1141. extern char fixedcomment[40], permanentcomment[40], interfacecomment[40];
  1142. extern char embedcomment[40],  skipcomment[40], noskipcomment[40];
  1143. extern char signedcomment[40], unsignedcomment[40];
  1144.  
  1145. extern char name_RETV[40], name_STRMAX[40], name_LINK[40];
  1146. extern char name_COPYPAR[40], name_TEMP[40], name_DUMMY[40];
  1147. extern char name_LOC[40], name_VARS[40], name_STRUCT[40];
  1148. extern char name_FAKESTRUCT[40], name_AHIGH[40], name_ALOW[40];
  1149. extern char name_UNION[40], name_VARIANT[40], name_LABEL[40], name_LABVAR[40];
  1150. extern char name_WITH[40], name_FOR[40], name_ENUM[40];
  1151. extern char name_PTR[40], name_STRING[40], name_SET[40];
  1152. extern char name_PROCEDURE[40], name_MAIN[40], name_UNITINIT[40];
  1153. extern char name_HSYMBOL[40], name_GSYMBOL[40];
  1154. extern char name_SETBITS[40], name_UCHAR[40], name_SCHAR[40];
  1155. extern char name_BOOLEAN[40], name_TRUE[40], name_FALSE[40], name_NULL[40];
  1156. extern char name_ESCAPECODE[40], name_IORESULT[40];
  1157. extern char name_ARGC[40], name_ARGV[40];
  1158. extern char name_ESCAPE[40], name_ESCIO[40], name_CHKIO[40], name_SETIO[40];
  1159. extern char name_OUTMEM[40], name_CASECHECK[40], name_NILCHECK[40];
  1160. extern char name_FNSIZE[40], name_FNVAR[40];
  1161. extern char alternatename1[40], alternatename2[40], alternatename[40];
  1162.  
  1163.  
  1164. #ifndef define_parameters
  1165. extern
  1166. #endif
  1167. struct rcstruct {
  1168.     char kind;
  1169.     char chgmode;
  1170.     char *name;
  1171.     anyptr ptr;
  1172.     long def;
  1173. } rctable[]
  1174. #ifdef define_parameters
  1175.    = {
  1176.     'S', 'R', "DEBUG",           (anyptr) &debug,             0,
  1177.     'I', 'R', "SHOWPROGRESS",    (anyptr) &showprogress,      0,
  1178.     'S', 'V', "TOKENTRACE",      (anyptr) &tokentrace,        0,
  1179.     'S', 'V', "QUIET",           (anyptr) &quietmode,         0,
  1180.     'S', 'V', "COPYSOURCE",      (anyptr) Â©source,        0,
  1181.     'I', 'R', "MAXERRORS",     (anyptr) &maxerrors,          0,
  1182.     'X', ' ', "INCLUDE",         (anyptr) NULL,               2,
  1183.  
  1184. /* INPUT LANGUAGE */
  1185.     'U', 'T', "LANGUAGE",        (anyptr)  language,         40,
  1186.     'S', 'V', "MODULA2",         (anyptr) &modula2,          -1,
  1187.     'S', 'T', "INTEGER16",       (anyptr) &integer16,        -1,
  1188.     'S', 'T', "DOUBLEREALS",     (anyptr) &doublereals,      -1,
  1189.     'S', 'V', "UNSIGNEDCHAR",    (anyptr) &unsignedchar,     -1,
  1190.     'S', 'V', "NEEDSIGNEDBYTE",  (anyptr) &needsignedbyte,    0,
  1191.     'S', 'V', "PASCALENUMSIZE",  (anyptr) &pascalenumsize,   -1,
  1192.     'S', 'V', "NESTEDCOMMENTS",  (anyptr) &nestedcomments,   -1,
  1193.     'S', 'V', "IMPORTALL",       (anyptr) &importall,        -1,
  1194.     'S', 'V', "IMPLMODULES",     (anyptr) &implementationmodules, -1,
  1195.     'A', 'V', "EXTERNWORDS",     (anyptr) &externwords,          0,
  1196.     'A', 'V', "CEXTERNWORDS",     (anyptr) &cexternwords,      0,
  1197.     'S', 'V', "PASCALSIGNIF",    (anyptr) &pascalsignif,     -1,
  1198.     'S', 'V', "PASCALCASESENS",  (anyptr) &pascalcasesens,   -1,
  1199.     'S', 'V', "DOLLARIDENTS",    (anyptr) &dollar_idents,    -1,
  1200.     'S', 'V', "IGNORENONALPHA",  (anyptr) &ignorenonalpha,   -1,
  1201.     'I', 'V', "SEEKBASE",        (anyptr) &seek_base,        -1,
  1202.     'I', 'R', "INPUTTABSIZE",    (anyptr) &intabsize,         8,
  1203.  
  1204. /* TARGET LANGUAGE */
  1205.     'S', 'T', "ANSIC",           (anyptr) &ansiC,            -1,
  1206.     'S', 'T', "C++",             (anyptr) &cplus,            -1,
  1207.     'S', 'T', "VOID*",           (anyptr) &voidstar,         -1,
  1208.     'S', 'T', "HASSIGNEDCHAR",   (anyptr) &hassignedchar,    -1,
  1209.     'S', 'V', "CASTNULL",        (anyptr) &castnull,         -1,
  1210.     'S', 'V', "COPYSTRUCTS",     (anyptr) Â©structs,      -1,
  1211.     'S', 'V', "VARIABLEARRAYS",  (anyptr) &variablearrays,   -1,
  1212.     'S', 'V', "INITPACSTRINGS",  (anyptr) &initpacstrings,   -1,
  1213.     'S', 'V', "REUSEFIELDNAMES", (anyptr) &reusefieldnames,   1,
  1214.     'S', 'V', "USEVEXTERN",      (anyptr) &usevextern,        1,
  1215.     'S', 'V', "CSIGNIF",         (anyptr) &csignif,          -1,
  1216.     'S', 'V', "USEANYPTRMACROS", (anyptr) &useAnyptrMacros,  -1,
  1217.     'S', 'V', "USEPPMACROS",     (anyptr) &usePPMacros,      -1,
  1218.  
  1219. /* TARGET MACHINE */
  1220.     'U', 'T', "TARGET",          (anyptr)  target,           40,
  1221.     'S', 'T', "SIGNEDCHAR",      (anyptr) &signedchars,      -1,
  1222.     'S', 'T', "SIGNEDFIELD",     (anyptr) &signedfield,      -1,
  1223.     'S', 'T', "SIGNEDSHIFT",     (anyptr) &signedshift,      -1,
  1224.     'I', 'T', "CHARSIZE",        (anyptr) &sizeof_char,       0,
  1225.     'I', 'T', "SHORTSIZE",       (anyptr) &sizeof_short,      0,
  1226.     'I', 'T', "INTSIZE",         (anyptr) &sizeof_int,        0,
  1227.     'I', 'T', "LONGSIZE",        (anyptr) &sizeof_long,       0,
  1228.     'I', 'T', "PTRSIZE",         (anyptr) &sizeof_pointer,    0,
  1229.     'I', 'T', "DOUBLESIZE",      (anyptr) &sizeof_double,     0,
  1230.     'I', 'T', "FLOATSIZE",       (anyptr) &sizeof_float,      0,
  1231.     'I', 'T', "ENUMSIZE",        (anyptr) &sizeof_enum,       0,
  1232.     'S', 'T', "SIZE_T_LONG",     (anyptr) &size_t_long,      -1,
  1233.  
  1234. /* BRACES */
  1235.     'S', 'V', "NULLSTMTLINE",    (anyptr) &nullstmtline,      0,
  1236.     'S', 'V', "BRACESALWAYS",    (anyptr) &bracesalways,     -1,
  1237.     'S', 'V', "BRACELINE",       (anyptr) &braceline,        -1,
  1238.     'S', 'V', "BRACECOMBINE",    (anyptr) &bracecombine,      0,
  1239.     'S', 'V', "BRACEELSE",       (anyptr) &braceelse,         0,
  1240.     'S', 'V', "BRACEELSELINE",   (anyptr) &braceelseline,     0,
  1241.     'S', 'V', "ELSEIF",          (anyptr) &elseif,           -1,
  1242.     'S', 'V', "NEWLINEFUNCS",    (anyptr) &newlinefunctions,  0,
  1243.  
  1244. /* INDENTATION */
  1245.     'I', 'R', "PHYSTABSIZE",     (anyptr) &phystabsize,       8,
  1246.     'D', 'R', "INDENT",          (anyptr) &tabsize,           2,
  1247.     'D', 'R', "BLOCKINDENT",     (anyptr) &blockindent,       0,
  1248.     'D', 'R', "BODYINDENT",      (anyptr) &bodyindent,        0,
  1249.     'D', 'R', "FUNCARGINDENT",   (anyptr) &argindent,      1000,
  1250.     'D', 'R', "OPENBRACEINDENT", (anyptr) &openbraceindent,   0,
  1251.     'D', 'R', "CLOSEBRACEINDENT",(anyptr) &closebraceindent,  0,
  1252.     'D', 'R', "FUNCOPENINDENT",  (anyptr) &funcopenindent,    0,
  1253.     'D', 'R', "FUNCCLOSEINDENT", (anyptr) &funccloseindent,   0,
  1254.     'D', 'R', "SWITCHINDENT",    (anyptr) &switchindent,      0,
  1255.     'D', 'R', "CASEINDENT",      (anyptr) &caseindent,       -2,
  1256.     'D', 'R', "LABELINDENT",     (anyptr) &labelindent,    1000,
  1257.     'D', 'R', "STRUCTINDENT",    (anyptr) &structindent,      0,
  1258.     'D', 'R', "STRUCTINITINDENT",(anyptr) &structinitindent,  0,
  1259.     'D', 'R', "EXTRAINITINDENT", (anyptr) &extrainitindent,   2,
  1260.     'I', 'R', "EXTRAINDENT",     (anyptr) &extraindent,       2,
  1261.     'I', 'R', "BUMPINDENT",      (anyptr) &bumpindent,        1,
  1262.     'D', 'R', "CONSTINDENT",     (anyptr) &constindent,    1024,
  1263.     'D', 'R', "COMMENTINDENT",   (anyptr) &commentindent,     3,
  1264.     'D', 'R', "BRACECOMMENTINDENT",(anyptr)&bracecommentindent, 2,
  1265.     'D', 'R', "DECLCOMMENTINDENT",(anyptr)&declcommentindent, -999,
  1266.     'D', 'R', "COMMENTOVERINDENT",(anyptr)&commentoverindent, 4,  /*1000*/
  1267.     'I', 'R', "MINSPACING",      (anyptr) &minspacing,        2,
  1268.     'I', 'R', "MINSPACINGTHRESH",(anyptr) &minspacingthresh, -1,
  1269.  
  1270. /* LINE BREAKING */
  1271.     'I', 'R', "LINEWIDTH",       (anyptr) &linewidth,        78,
  1272.     'I', 'R', "MAXLINEWIDTH",    (anyptr) &maxlinewidth,     90,
  1273.     'R', 'V', "OVERWIDEPENALTY",       (anyptr) &overwidepenalty,         2500,
  1274.     'R', 'V', "OVERWIDEEXTRAPENALTY",  (anyptr) &overwideextrapenalty,     100,
  1275.     'R', 'V', "COMMABREAKPENALTY",     (anyptr) &commabreakpenalty,       1000,
  1276.     'R', 'V', "COMMABREAKEXTRAPENALTY",(anyptr) &commabreakextrapenalty,   500,
  1277.     'R', 'V', "ASSIGNBREAKPENALTY",    (anyptr) &assignbreakpenalty,      5000,
  1278.     'R', 'V', "ASSIGNBREAKEXTRAPENALTY",(anyptr)&assignbreakextrapenalty, 3000,
  1279.     'R', 'V', "SPECIALARGBREAKPENALTY",(anyptr) &specialargbreakpenalty,   500,
  1280.     'R', 'V', "OPBREAKPENALTY",        (anyptr) &opbreakpenalty,          2500,
  1281.     'R', 'V', "OPBREAKEXTRAPENALTY",   (anyptr) &opbreakextrapenalty,     2000,
  1282.     'R', 'V', "LOGBREAKPENALTY",       (anyptr) &logbreakpenalty,          500,
  1283.     'R', 'V', "LOGBREAKEXTRAPENALTY",  (anyptr) &logbreakextrapenalty,     100,
  1284.     'R', 'V', "RELBREAKPENALTY",       (anyptr) &relbreakpenalty,         2000,
  1285.     'R', 'V', "RELBREAKEXTRAPENALTY",  (anyptr) &relbreakextrapenalty,    1000,
  1286.     'R', 'V', "EXHYPHENPENALTY",       (anyptr) &exhyphenpenalty,         1000,
  1287.     'R', 'V', "MOREBREAKPENALTY",      (anyptr) &morebreakpenalty,        -500,
  1288.     'R', 'V', "MOREBREAKEXTRAPENALTY", (anyptr) &morebreakextrapenalty,   -300,
  1289.     'R', 'V', "QMARKBREAKPENALTY",     (anyptr) &qmarkbreakpenalty,       5000,
  1290.     'R', 'V', "QMARKBREAKEXTRAPENALTY",(anyptr) &qmarkbreakextrapenalty,  3000,
  1291.     'R', 'V', "PARENBREAKPENALTY",     (anyptr) &parenbreakpenalty,       2500,
  1292.     'R', 'V', "PARENBREAKEXTRAPENALTY",(anyptr) &parenbreakextrapenalty,  1000,
  1293.     'R', 'V', "WRONGSIDEPENALTY",      (anyptr) &wrongsidepenalty,        1000,
  1294.     'R', 'V', "EARLYBREAKPENALTY",     (anyptr) &earlybreakpenalty,        100,
  1295.     'R', 'V', "EXTRAINDENTPENALTY",    (anyptr) &extraindentpenalty,      3000,
  1296.     'R', 'V', "BUMPINDENTPENALTY",     (anyptr) &bumpindentpenalty,       1000,
  1297.     'R', 'V', "NOBUMPINDENTPENALTY",   (anyptr) &nobumpindentpenalty,     2500,
  1298.     'R', 'V', "INDENTAMOUNTPENALTY",   (anyptr) &indentamountpenalty,       50,
  1299.     'R', 'V', "SAMEINDENTPENALTY",     (anyptr) &sameindentpenalty,        500,
  1300.     'R', 'V', "SHOWBADLIMIT",          (anyptr) &showbadlimit,            -120,
  1301.     'L', 'R', "MAXLINEBREAKTRIES", (anyptr) &maxalts,      5000,
  1302.     'G', 'V', "ALLORNONEBREAK",  (anyptr)  NULL,             FALLBREAK,
  1303.     'G', 'V', "ONESPECIALARG",   (anyptr)  NULL,             FSPCARG1,
  1304.     'G', 'V', "TWOSPECIALARGS",  (anyptr)  NULL,             FSPCARG2,
  1305.     'G', 'V', "THREESPECIALARGS",(anyptr)  NULL,             FSPCARG3,
  1306.     'B', 'V', "BREAKARITH",      (anyptr) &breakbeforearith,  BRK_RIGHT,
  1307.     'B', 'V', "BREAKREL",        (anyptr) &breakbeforerel,    BRK_RIGHT,
  1308.     'B', 'V', "BREAKLOG",        (anyptr) &breakbeforelog,    BRK_RIGHT,
  1309.     'B', 'V', "BREAKDOT",        (anyptr) &breakbeforedot,    BRK_RIGHT,
  1310.     'B', 'V', "BREAKASSIGN",     (anyptr) &breakbeforeassign, BRK_RIGHT,
  1311.     'S', 'V', "FOR_ALLORNONE",   (anyptr) &for_allornone,     1,
  1312.  
  1313. /* COMMENTS AND BLANK LINES */
  1314.     'S', 'V', "NOBANNER",        (anyptr) &nobanner,          0,
  1315.     'S', 'V', "EATCOMMENTS",     (anyptr) &eatcomments,       0,
  1316.     'S', 'V', "SPITCOMMENTS",    (anyptr) &spitcomments,      0,
  1317.     'S', 'V', "SPITORPHANCOMMENTS",(anyptr)&spitorphancomments, 0,
  1318.     'S', 'V', "COMMENTAFTER",    (anyptr) &commentafter,     -1,
  1319.     'S', 'V', "BLANKAFTER",      (anyptr) &blankafter,        1,
  1320.     'A', 'V', "EATNOTES",        (anyptr) &eatnotes,          0,
  1321.  
  1322. /* SPECIAL COMMENTS */
  1323.     'C', 'V', "FIXEDCOMMENT",    (anyptr)  fixedcomment,     40,
  1324.     'C', 'V', "PERMANENTCOMMENT",(anyptr)  permanentcomment, 40,
  1325.     'C', 'V', "INTERFACECOMMENT",(anyptr)  interfacecomment, 40,
  1326.     'C', 'V', "EMBEDCOMMENT",    (anyptr)  embedcomment,     40,
  1327.     'C', 'V', "SKIPCOMMENT",     (anyptr)  skipcomment,      40,
  1328.     'C', 'V', "NOSKIPCOMMENT",   (anyptr)  noskipcomment,    40,
  1329.     'C', 'V', "SIGNEDCOMMENT",   (anyptr)  signedcomment,    40,
  1330.     'C', 'V', "UNSIGNEDCOMMENT", (anyptr)  unsignedcomment,  40,
  1331.  
  1332. /* STYLISTIC OPTIONS */
  1333.     'I', 'V', "MAJORSPACING",    (anyptr) &majorspace,        2,
  1334.     'I', 'V', "MINORSPACING",    (anyptr) &minorspace,        1,
  1335.     'I', 'V', "FUNCSPACING",     (anyptr) &functionspace,     2,
  1336.     'I', 'V', "MINFUNCSPACING",  (anyptr) &minfuncspace,      1,
  1337.     'S', 'V', "EXTRAPARENS",     (anyptr) &extraparens,      -1,
  1338.     'S', 'V', "BREAKADDPARENS",  (anyptr) &breakparens,      -1,
  1339.     'S', 'V', "RETURNPARENS",    (anyptr) &returnparens,     -1,
  1340.     'S', 'V', "SPACEEXPRS",      (anyptr) &spaceexprs,       -1,
  1341.     'S', 'V', "SPACEFUNCS",     (anyptr) &spacefuncs,          0,
  1342.     'S', 'V', "SPACECOMMAS",     (anyptr) &spacecommas,          1,
  1343.     'S', 'V', "IMPLICITZERO",    (anyptr) &implicitzero,     -1,
  1344.     'S', 'V', "STARINDEX",       (anyptr) &starindex,        -1,
  1345.     'S', 'V', "ADDINDEX",        (anyptr) &addindex,         -1,
  1346.     'S', 'V', "STARARRAYS",      (anyptr) &stararrays,        1,
  1347.     'S', 'V', "STARFUNCTIONS",   (anyptr) &starfunctions,    -1,
  1348.     'S', 'V', "POSTINCREMENT",   (anyptr) &postincrement,     1,
  1349.     'S', 'V', "MIXVARS",         (anyptr) &mixvars,          -1,
  1350.     'S', 'V', "MIXTYPES",        (anyptr) &mixtypes,         -1,
  1351.     'S', 'V', "MIXFIELDS",       (anyptr) &mixfields,        -1,
  1352.     'S', 'V', "MIXINITS",        (anyptr) &mixinits,         -1,
  1353.     'S', 'V', "MAINLOCALS",      (anyptr) &mainlocals,        1,
  1354.     'S', 'V', "NULLCHAR",        (anyptr) &nullcharconst,     1,
  1355.     'S', 'V', "HIGHCHARINT",     (anyptr) &highcharints,      1,
  1356.     'I', 'V', "CASESPACING",     (anyptr) &casespacing,       1,
  1357.     'D', 'V', "CASETABS",        (anyptr) &casetabs,       1000,
  1358.     'I', 'V', "CASELIMIT",       (anyptr) &caselimit,         9,
  1359.     'S', 'V', "USECOMMAS",       (anyptr) &usecommas,        -1,
  1360.     'S', 'V', "USERETURNS",      (anyptr) &usereturns,        1,
  1361.     'I', 'V', "RETURNLIMIT",     (anyptr) &returnlimit,       3,
  1362.     'S', 'V', "USEBREAKS",       (anyptr) &usebreaks,         1,
  1363.     'I', 'V', "BREAKLIMIT",      (anyptr) &breaklimit,        2,
  1364.     'I', 'V', "CONTINUELIMIT",   (anyptr) &continuelimit,     5,
  1365.     'S', 'V', "INFLOOPSTYLE",    (anyptr) &infloopstyle,      0,
  1366.  
  1367. /* NAMING CONVENTIONS */
  1368.     'C', 'V', "CODEFILENAME",    (anyptr)  codefnfmt,        40,
  1369.     'C', 'V', "MODULEFILENAME",  (anyptr)  modulefnfmt,      40,
  1370.     'C', 'V', "HEADERFILENAME",  (anyptr)  headerfnfmt,      40,
  1371.     'C', 'V', "HEADERFILENAME2", (anyptr)  headerfnfmt2,     40,
  1372.     'C', 'V', "SELFINCLUDENAME", (anyptr)  selfincludefmt,   40,
  1373.     'C', 'V', "LOGFILENAME",     (anyptr)  logfnfmt,         40,
  1374.     'C', 'V', "INCLUDEFILENAME", (anyptr)  includefnfmt,     40,
  1375.     'S', 'V', "SYMCASE",         (anyptr) &symcase,          -1,
  1376.     'C', 'V', "SYMBOLFORMAT",    (anyptr)  symbolformat,     40,
  1377.     'C', 'V', "CONSTFORMAT",     (anyptr)  constformat,      40,
  1378.     'C', 'V', "MODULEFORMAT",    (anyptr)  moduleformat,     40,
  1379.     'C', 'V', "FUNCTIONFORMAT",  (anyptr)  functionformat,   40,
  1380.     'C', 'V', "VARFORMAT",       (anyptr)  varformat,        40,
  1381.     'C', 'V', "FIELDFORMAT",     (anyptr)  fieldformat,      40,
  1382.     'C', 'V', "TYPEFORMAT",      (anyptr)  typeformat,       40,
  1383.     'C', 'V', "ENUMFORMAT",      (anyptr)  enumformat,       40,
  1384.     'C', 'V', "RETURNVALUENAME", (anyptr)  name_RETV,        40,
  1385.     'C', 'V', "UNITINITNAME",    (anyptr)  name_UNITINIT,    40,
  1386.     'C', 'V', "HSYMBOLNAME",     (anyptr)  name_HSYMBOL,     40,
  1387.     'C', 'V', "GSYMBOLNAME",     (anyptr)  name_GSYMBOL,     40,
  1388.     'C', 'V', "STRINGMAXNAME",   (anyptr)  name_STRMAX,      40,
  1389.     'C', 'V', "ARRAYMINNAME",    (anyptr)  name_ALOW,        40,
  1390.     'C', 'V', "ARRAYMAXNAME",    (anyptr)  name_AHIGH,       40,
  1391.     'C', 'V', "COPYPARNAME",     (anyptr)  name_COPYPAR,     40,
  1392.     'C', 'V', "STATICLINKNAME",  (anyptr)  name_LINK,        40,
  1393.     'C', 'V', "LOCALVARSSTRUCT", (anyptr)  name_LOC,         40,
  1394.     'C', 'V', "LOCALVARSNAME",   (anyptr)  name_VARS,        40,
  1395.     'C', 'V', "FWDSTRUCTNAME",   (anyptr)  name_STRUCT,      40,
  1396.     'C', 'V', "ENUMLISTNAME",    (anyptr)  name_ENUM,        40,
  1397.     'C', 'V', "UNIONNAME",       (anyptr)  name_UNION,       40,
  1398.     'C', 'V', "UNIONPARTNAME",   (anyptr)  name_VARIANT,     40,
  1399.     'C', 'V', "FAKESTRUCTNAME",  (anyptr)  name_FAKESTRUCT,  40,
  1400.     'C', 'V', "LABELNAME",       (anyptr)  name_LABEL,       40,
  1401.     'C', 'V', "LABELVARNAME",    (anyptr)  name_LABVAR,      40,
  1402.     'C', 'V', "TEMPNAME",        (anyptr)  name_TEMP,        40,
  1403.     'C', 'V', "DUMMYNAME",       (anyptr)  name_DUMMY,       40,
  1404.     'C', 'V', "FORNAME",         (anyptr)  name_FOR,         40,
  1405.     'C', 'V', "WITHNAME",        (anyptr)  name_WITH,        40,
  1406.     'C', 'V', "PTRNAME",         (anyptr)  name_PTR,         40,
  1407.     'C', 'V', "STRINGNAME",      (anyptr)  name_STRING,      40,
  1408.     'C', 'V', "SETNAME",         (anyptr)  name_SET,         40,
  1409.     'C', 'V', "FNVARNAME",       (anyptr)  name_FNVAR,       40,
  1410.     'C', 'V', "FNSIZENAME",      (anyptr)  name_FNSIZE,      40,
  1411.     'C', 'V', "ALTERNATENAME1",  (anyptr)  alternatename1,   40,
  1412.     'C', 'V', "ALTERNATENAME2",  (anyptr)  alternatename2,   40,
  1413.     'C', 'V', "ALTERNATENAME",   (anyptr)  alternatename,    40,
  1414.     'C', 'V', "EXPORTSYMBOL",    (anyptr)  exportsymbol,     40,
  1415.     'C', 'V', "EXPORT_SYMBOL",   (anyptr)  export_symbol,    40,
  1416.     'C', 'V', "ALIAS",           (anyptr)  externalias,      40,
  1417.     'X', 'V', "SYNONYM",         (anyptr)  NULL,              3,
  1418.     'X', 'V', "NAMEOF",          (anyptr) &nameoflist,        1,
  1419.     'G', 'V', "AVOIDNAME",       (anyptr)  NULL,             AVOIDNAME,
  1420.     'G', 'V', "AVOIDGLOBALNAME", (anyptr)  NULL,             AVOIDGLOB,
  1421.     'G', 'V', "WARNNAME",        (anyptr)  NULL,             WARNNAME,
  1422.     'G', 'V', "NOSIDEEFFECTS",   (anyptr)  NULL,             NOSIDEEFF,
  1423.     'G', 'V', "STRUCTFUNCTION",  (anyptr)  NULL,             STRUCTF,
  1424.     'G', 'V', "STRLAPFUNCTION",  (anyptr)  NULL,             STRLAPF,
  1425.     'F', 'V', "LEAVEALONE",      (anyptr)  NULL,             LEAVEALONE,
  1426.     'G', 'V', "DETERMINISTIC",   (anyptr)  NULL,             DETERMF,
  1427.     'G', 'V', "NEEDSTATIC",      (anyptr)  NULL,             NEEDSTATIC,
  1428.     'S', 'V', "WARNNAMES",       (anyptr) &warnnames,         0,
  1429.     'M', 'V', "VARMACRO",        (anyptr)  NULL,             MAC_VAR,
  1430.     'M', 'V', "CONSTMACRO",      (anyptr)  NULL,             MAC_CONST,
  1431.     'M', 'V', "FIELDMACRO",      (anyptr)  NULL,             MAC_FIELD,
  1432.     'M', 'V', "FUNCMACRO",       (anyptr)  NULL,             MAC_FUNC,
  1433.     'S', 'V', "WARNMACROS",      (anyptr) &warnmacros,        0,
  1434.  
  1435. /* CODING OPTIONS */
  1436.     'A', 'V', "INITIALCALLS",    (anyptr) &initialcalls,      0,
  1437.     'S', 'V', "EXPANDINCLUDES",  (anyptr) &expandincludes,   -1,
  1438.     'S', 'V', "COLLECTNEST",     (anyptr) &collectnest,       1,
  1439.     'S', 'V', "SHORTCIRCUIT",    (anyptr) &shortcircuit,     -1,
  1440.     'S', 'V', "SHORTOPT",        (anyptr) &shortopt,          1,
  1441.     'S', 'V', "ELIMDEADCODE",    (anyptr) &elimdeadcode,      1,
  1442.     'S', 'V', "FOLDCONSTANTS",   (anyptr) &foldconsts,       -1,
  1443.     'S', 'V', "FOLDSTRCONSTANTS",(anyptr) &foldstrconsts,    -1,
  1444.     'S', 'V', "CHARCONSTS",     (anyptr) &charconsts,        1,
  1445.     'S', 'V', "USECONSTS",       (anyptr) &useconsts,        -1,
  1446.     'S', 'V', "USEUNDEF",        (anyptr) &useundef,          1,
  1447.     'L', 'V', "SKIPINDICES",     (anyptr) &skipindices,       0,
  1448.     'S', 'V', "OFFSETFORLOOPS",  (anyptr) &offsetforloops,    1,
  1449.     'S', 'V', "FOREVALORDER",    (anyptr) &forevalorder,      0,
  1450.     'S', 'V', "STRINGLEADERS",   (anyptr) &stringleaders,     2,
  1451.     'S', 'V', "STOREFILENAMES",  (anyptr) &storefilenames,   -1,
  1452.     'S', 'V', "CHARFILETEXT",    (anyptr) &charfiletext,     -1,
  1453.     'S', 'V', "SQUEEZESUBR",     (anyptr) &squeezesubr,       1,
  1454.     'S', 'T', "USEENUM",         (anyptr) &useenum,          -1,
  1455.     'S', 'V', "SQUEEZEENUM",     (anyptr) &enumbyte,         -1,
  1456.     'S', 'V', "COMPENUMS",       (anyptr) &compenums,        -1,
  1457.     'S', 'V', "PRESERVETYPES",   (anyptr) &preservetypes,     1,
  1458.     'S', 'V', "PRESERVEPOINTERS",(anyptr) &preservepointers,  0,
  1459.     'S', 'V', "PRESERVESTRINGS", (anyptr) &preservestrings,  -1,
  1460.     'S', 'V', "PACKING",         (anyptr) &packing,           1,
  1461.     'S', 'V', "PACKSIGNED",      (anyptr) &packsigned,        1,
  1462.     'I', 'V', "STRINGCEILING",   (anyptr) &stringceiling,   255,
  1463.     'I', 'V', "STRINGDEFAULT",   (anyptr) &stringdefault,   255,
  1464.     'I', 'V', "STRINGTRUNCLIMIT",(anyptr) &stringtrunclimit, -1,
  1465.     'I', 'V', "LONGSTRINGSIZE",  (anyptr) &longstringsize,   -1,
  1466.     'S', 'V', "KEEPNULLS",       (anyptr) &keepnulls,         0,
  1467.     'S', 'V', "HIGHCHARBITS",    (anyptr) &highcharbits,     -1,
  1468.     'S', 'V', "ALWAYSCOPYVALUES",(anyptr) &alwayscopyvalues,  0,
  1469.     'S', 'V', "STATICFUNCTIONS", (anyptr) &use_static,        1,
  1470.     'S', 'V', "STATICVARIABLES", (anyptr) &var_static,        1,
  1471.     'S', 'V', "VOIDARGS",        (anyptr) &void_args,        -1,
  1472.     'S', 'V', "PROTOTYPES",      (anyptr) &prototypes,       -1,
  1473.     'S', 'V', "FULLPROTOTYPING", (anyptr) &fullprototyping,  -1,
  1474.     'S', 'V', "PROCPTRPROTOTYPES",(anyptr)&procptrprototypes, 1,
  1475.     'S', 'V', "CASTARGS",        (anyptr) &castargs,         -1,
  1476.     'S', 'V', "CASTLONGARGS",    (anyptr) &castlongargs,     -1,
  1477.     'S', 'V', "PROMOTEARGS",     (anyptr) &promoteargs,      -1,
  1478.     'S', 'V', "FIXPROMOTEDARGS", (anyptr) &fixpromotedargs,   1,
  1479.     'S', 'V', "PROMOTEENUMS",    (anyptr) &promote_enums,    -1,
  1480.     'S', 'V', "STATICLINKS",     (anyptr) &hasstaticlinks,   -1,
  1481.     'S', 'V', "VARSTRINGS",      (anyptr) &varstrings,        0,
  1482.     'S', 'V', "VARFILES",        (anyptr) &varfiles,          1,
  1483.     'S', 'V', "ADDRSTDFILES",    (anyptr) &addrstdfiles,      0,
  1484.     'S', 'V', "COPYSTRUCTFUNCS", (anyptr) Â©structfuncs,  -1,
  1485.     'S', 'V', "ATAN2",           (anyptr) &atan2flag,         0,
  1486.     'S', 'V', "BITWISEMOD",      (anyptr) &mod_po2,          -1,
  1487.     'S', 'V', "BITWISEDIV",      (anyptr) &div_po2,          -1,
  1488.     'S', 'V', "ASSUMEBITS",      (anyptr) &assumebits,        0,
  1489.     'S', 'V', "ASSUMESIGNS",     (anyptr) &assumesigns,       1,
  1490.     'S', 'V', "ALLOCZERONIL",    (anyptr) &alloczeronil,      0,
  1491.     'S', 'V', "PRINTFONLY",      (anyptr) &printfonly,       -1,
  1492.     'S', 'V', "MIXWRITELNS",     (anyptr) &mixwritelns,       1,
  1493.     'S', 'V', "MESSAGESTDERR",   (anyptr) &messagestderr,     1,
  1494.     'I', 'V', "INTEGERWIDTH",    (anyptr) &integerwidth,     -1,
  1495.     'I', 'V', "REALWIDTH",       (anyptr) &realwidth,        12,
  1496.     'S', 'V', "FORMATSTRINGS",   (anyptr) &formatstrings,     0,
  1497.     'S', 'V', "WHILEFGETS",      (anyptr) &whilefgets,        1,
  1498.     'S', 'V', "USEGETS",         (anyptr) &usegets,           1,
  1499.     'S', 'V', "NEWLINESPACE",    (anyptr) &newlinespace,     -1,
  1500.     'S', 'V', "BUILDREADS",      (anyptr) &buildreads,        1,
  1501.     'S', 'V', "BUILDWRITES",     (anyptr) &buildwrites,       1,
  1502.     'S', 'V', "BINARYMODE",      (anyptr) &binarymode,        1,
  1503.     'S', 'V', "READWRITEOPEN",   (anyptr) &readwriteopen,    -1,
  1504.     'C', 'V', "OPENMODE",        (anyptr)  openmode,         40,
  1505.     'S', 'V', "LITERALFILES",    (anyptr) &literalfilesflag, -1,
  1506.     'A', 'V', "LITERALFILE",     (anyptr) &literalfiles,      0,
  1507.     'S', 'V', "STRUCTFILES",     (anyptr) &structfilesflag,   0,
  1508.     'A', 'V', "STRUCTFILE",      (anyptr) &structfiles,       0,
  1509.     'C', 'V', "FILENAMEFILTER",  (anyptr)  filenamefilter,   40,
  1510.     'S', 'V', "FULLSTRWRITE",    (anyptr) &fullstrwrite,     -1,
  1511.     'S', 'V', "FULLSTRREAD",     (anyptr) &fullstrread,       1,
  1512.     'I', 'R', "SETBITS",         (anyptr) &setbits,          -1,
  1513.     'I', 'V', "DEFAULTSETSIZE",  (anyptr) &defaultsetsize,   -1,
  1514.     'S', 'V', "SMALLSETCONST",   (anyptr) &smallsetconst,    -2,
  1515.     'S', 'V', "BIGSETCONST",     (anyptr) &bigsetconst,       1,
  1516.     'S', 'V', "LELERANGE",       (anyptr) &lelerange,         0,
  1517.     'S', 'V', "UNSIGNEDTRICK",   (anyptr) &unsignedtrick,     1,
  1518.     'S', 'V', "USEISALPHA",      (anyptr) &useisalpha,        1,
  1519.     'S', 'V', "USEISSPACE",      (anyptr) &useisspace,        0,
  1520.     'S', 'V', "USESTRNCMP",     (anyptr) &usestrncmp,          1,
  1521.  
  1522. /* TARGET LIBRARY */
  1523.     'G', 'V', "WARNLIBRARY",     (anyptr)  NULL,             WARNLIBR,
  1524.     'S', 'V', "QUOTEINCLUDES",   (anyptr) "eincludes,     1,
  1525.     'X', 'V', "IMPORTFROM",      (anyptr) &importfrom,        1,
  1526.     'A', 'V', "IMPORTDIR",       (anyptr) &importdirs,        0,
  1527.     'A', 'V', "INCLUDEDIR",      (anyptr) &includedirs,       0,
  1528.     'X', 'V', "INCLUDEFROM",     (anyptr) &includefrom,       1,
  1529.     'A', 'V', "LIBRARYFILE",     (anyptr) &librfiles,         0,
  1530.     'C', 'V', "HEADERNAME",      (anyptr)  p2c_h_name,       40,
  1531.     'C', 'V', "PROCTYPENAME",    (anyptr)  name_PROCEDURE,   40,
  1532.     'C', 'V', "UCHARNAME",       (anyptr)  name_UCHAR,       40,
  1533.     'C', 'V', "SCHARNAME",       (anyptr)  name_SCHAR,       40,
  1534.     'C', 'V', "BOOLEANNAME",     (anyptr)  name_BOOLEAN,     40,
  1535.     'C', 'V', "TRUENAME",        (anyptr)  name_TRUE,        40,
  1536.     'C', 'V', "FALSENAME",       (anyptr)  name_FALSE,       40,
  1537.     'C', 'V', "NULLNAME",        (anyptr)  name_NULL,        40,
  1538.     'C', 'V', "ESCAPECODENAME",  (anyptr)  name_ESCAPECODE,  40,
  1539.     'C', 'V', "IORESULTNAME",    (anyptr)  name_IORESULT,    40,
  1540.     'C', 'V', "ARGCNAME",        (anyptr)  name_ARGC,        40,
  1541.     'C', 'V', "ARGVNAME",        (anyptr)  name_ARGV,        40,
  1542.     'C', 'V', "MAINNAME",        (anyptr)  name_MAIN,        40,
  1543.     'C', 'V', "ESCAPENAME",      (anyptr)  name_ESCAPE,      40,
  1544.     'C', 'V', "ESCIONAME",       (anyptr)  name_ESCIO,       40,
  1545.     'C', 'V', "CHECKIONAME",     (anyptr)  name_CHKIO,       40,
  1546.     'C', 'V', "SETIONAME",       (anyptr)  name_SETIO,       40,
  1547.     'C', 'V', "FILENOTFOUNDNAME",(anyptr)  filenotfoundname, 40,
  1548.     'C', 'V', "FILENOTOPENNAME", (anyptr)  filenotopenname,  40,
  1549.     'C', 'V', "FILEWRITEERRORNAME",(anyptr)filewriteerrorname,40,
  1550.     'C', 'V', "BADINPUTFORMATNAME",(anyptr)badinputformatname,40,
  1551.     'C', 'V', "ENDOFFILENAME",   (anyptr)  endoffilename,    40,
  1552.     'C', 'V', "OUTMEMNAME",      (anyptr)  name_OUTMEM,      40,
  1553.     'C', 'V', "CASECHECKNAME",   (anyptr)  name_CASECHECK,   40,
  1554.     'C', 'V', "NILCHECKNAME",    (anyptr)  name_NILCHECK,    40,
  1555.     'C', 'V', "SETBITSNAME",     (anyptr)  name_SETBITS,     40,
  1556.     'S', 'V', "SPRINTFVALUE",    (anyptr) &sprintf_value,    -1,
  1557.     'C', 'V', "SPRINTFNAME",     (anyptr)  sprintfname,      40,
  1558.     'C', 'V', "MEMCPYNAME",      (anyptr)  memcpyname,       40,
  1559.     'C', 'V', "ROUNDNAME",       (anyptr)  roundname,        40,
  1560.     'C', 'V', "DIVNAME",     (anyptr)  divname,         40,
  1561.     'C', 'V', "MODNAME",     (anyptr)  modname,         40,
  1562.     'C', 'V', "REMNAME",     (anyptr)  remname,         40,
  1563.     'C', 'V', "STRCICMPNAME",    (anyptr)  strcicmpname,     40,
  1564.     'C', 'V', "STRSUBNAME",      (anyptr)  strsubname,       40,
  1565.     'C', 'V', "STRPOSNAME",      (anyptr)  strposname,       40,
  1566.     'S', 'V', "STRCPYLEFT",      (anyptr) &strcpyleft,        1,
  1567.     'C', 'V', "STRDELETENAME",   (anyptr)  strdeletename,    40,
  1568.     'C', 'V', "STRINSERTNAME",   (anyptr)  strinsertname,    40,
  1569.     'C', 'V', "STRMOVENAME",     (anyptr)  strmovename,         40,
  1570.     'C', 'V', "STRLTRIMNAME",    (anyptr)  strltrimname,     40,
  1571.     'C', 'V', "STRRTRIMNAME",    (anyptr)  strrtrimname,     40,
  1572.     'C', 'V', "STRRPTNAME",      (anyptr)  strrptname,       40,
  1573.     'C', 'V', "STRPADNAME",      (anyptr)  strpadname,       40,
  1574.     'C', 'V', "ABSNAME",         (anyptr)  absname,          40,
  1575.     'C', 'V', "ODDNAME",         (anyptr)  oddname,          40,
  1576.     'C', 'V', "EVENNAME",        (anyptr)  evenname,         40,
  1577.     'C', 'V', "SWAPNAME",        (anyptr)  swapname,         40,
  1578.     'C', 'V', "MALLOCNAME",      (anyptr)  mallocname,       40,
  1579.     'C', 'V', "FREENAME",        (anyptr)  freename,         40,
  1580.     'C', 'V', "FREERVALUENAME",  (anyptr)  freervaluename,   40,
  1581.     'X', 'V', "SPECIALMALLOC",   (anyptr) &specialmallocs,    1,
  1582.     'X', 'V', "SPECIALFREE",     (anyptr) &specialfrees,      1,
  1583.     'X', 'V', "SPECIALSIZEOF",   (anyptr) &specialsizeofs,    1,
  1584.     'C', 'V', "RANDREALNAME",    (anyptr)  randrealname,     40,
  1585.     'C', 'V', "RANDINTNAME",     (anyptr)  randintname,      40,
  1586.     'C', 'V', "RANDOMIZENAME",   (anyptr)  randomizename,    40,
  1587.     'C', 'V', "SKIPSPACENAME",   (anyptr)  skipspacename,    40,
  1588.     'C', 'V', "READLNNAME",      (anyptr)  readlnname,       40,
  1589.     'C', 'V', "FREOPENNAME",     (anyptr)  freopenname,      40,
  1590.     'C', 'V', "EOFNAME",         (anyptr)  eofname,          40,
  1591.     'C', 'V', "EOLNNAME",        (anyptr)  eolnname,         40,
  1592.     'C', 'V', "FILEPOSNAME",     (anyptr)  fileposname,      40,
  1593.     'C', 'V', "MAXPOSNAME",      (anyptr)  maxposname,       40,
  1594.     'C', 'V', "SETUNIONNAME",    (anyptr)  setunionname,     40,
  1595.     'C', 'V', "SETINTNAME",      (anyptr)  setintname,       40,
  1596.     'C', 'V', "SETDIFFNAME",     (anyptr)  setdiffname,      40,
  1597.     'C', 'V', "SETXORNAME",      (anyptr)  setxorname,       40,
  1598.     'C', 'V', "SETINNAME",       (anyptr)  setinname,        40,
  1599.     'C', 'V', "SETADDNAME",      (anyptr)  setaddname,       40,
  1600.     'C', 'V', "SETADDRANGENAME", (anyptr)  setaddrangename,  40,
  1601.     'C', 'V', "SETREMNAME",      (anyptr)  setremname,       40,
  1602.     'C', 'V', "SETEQUALNAME",    (anyptr)  setequalname,     40,
  1603.     'C', 'V', "SUBSETNAME",      (anyptr)  subsetname,       40,
  1604.     'C', 'V', "SETCOPYNAME",     (anyptr)  setcopyname,      40,
  1605.     'C', 'V', "SETEXPANDNAME",   (anyptr)  setexpandname,    40,
  1606.     'C', 'V', "SETPACKNAME",     (anyptr)  setpackname,      40,
  1607.     'C', 'V', "SIGNEXTENDNAME",  (anyptr)  signextname,      40,
  1608.     'C', 'V', "GETBITSNAME",     (anyptr)  getbitsname,      40,
  1609.     'C', 'V', "CLRBITSNAME",     (anyptr)  clrbitsname,      40,
  1610.     'C', 'V', "PUTBITSNAME",     (anyptr)  putbitsname,      40,
  1611.     'C', 'V', "STOREBITSNAME",   (anyptr)  storebitsname,    40,
  1612.     'C', 'V', "DECLBUFNAME",     (anyptr)  declbufname,         40,
  1613.     'C', 'V', "DECLBUFNCNAME",     (anyptr)  declbufncname,    40,
  1614.     'A', 'V', "BUFFEREDFILE",    (anyptr) &bufferedfiles,     0,
  1615.     'A', 'V', "UNBUFFEREDFILE",  (anyptr) &unbufferedfiles,   0,
  1616.     'C', 'V', "RESETBUFNAME",     (anyptr)  resetbufname,     40,
  1617.     'C', 'V', "SETUPBUFNAME",     (anyptr)  setupbufname,     40,
  1618.     'C', 'V', "GETFBUFNAME",     (anyptr)  getfbufname,      40,
  1619.     'C', 'V', "CHARGETFBUFNAME", (anyptr)  chargetfbufname,  40,
  1620.     'C', 'V', "ARRAYGETFBUFNAME",(anyptr)  arraygetfbufname, 40,
  1621.     'C', 'V', "PUTFBUFNAME",     (anyptr)  putfbufname,      40,
  1622.     'C', 'V', "CHARPUTFBUFNAME", (anyptr)  charputfbufname,  40,
  1623.     'C', 'V', "ARRAYPUTFBUFNAME",(anyptr)  arrayputfbufname, 40,
  1624.     'C', 'V', "GETNAME",         (anyptr)  getname,          40,
  1625.     'C', 'V', "CHARGETNAME",     (anyptr)  chargetname,      40,
  1626.     'C', 'V', "ARRAYGETNAME",    (anyptr)  arraygetname,     40,
  1627.     'C', 'V', "PUTNAME",         (anyptr)  putname,          40,
  1628.     'C', 'V', "CHARPUTNAME",     (anyptr)  charputname,      40,
  1629.     'C', 'V', "ARRAYPUTNAME",    (anyptr)  arrayputname,     40,
  1630.     'C', 'V', "EOFBUFNAME",      (anyptr)  eofbufname,       40,
  1631.     'C', 'V', "FILEPOSBUFNAME",  (anyptr)  fileposbufname,   40,
  1632.  
  1633. /* RANGE CHECKING */
  1634.     'S', 'V', "CASECHECK",       (anyptr) &casecheck,         0,
  1635.     'S', 'V', "ARRAYCHECK",      (anyptr) &arraycheck,        0,
  1636.     'S', 'V', "RANGECHECK",      (anyptr) &rangecheck,        0,
  1637.     'S', 'V', "NILCHECK",        (anyptr) &nilcheck,          0,
  1638.     'S', 'V', "MALLOCCHECK",     (anyptr) &malloccheck,       0,
  1639.     'S', 'V', "CHECKFILEOPEN",   (anyptr) &checkfileopen,     1,
  1640.     'S', 'V', "CHECKFILEISOPEN", (anyptr) &checkfileisopen,   0,
  1641.     'S', 'V', "CHECKFILEWRITE",  (anyptr) &checkfilewrite,    2,
  1642.     'S', 'V', "CHECKREADFORMAT", (anyptr) &checkreadformat,   2,
  1643.     'S', 'V', "CHECKFILEEOF",    (anyptr) &checkfileeof,      2,
  1644.     'S', 'V', "CHECKSTDINEOF",   (anyptr) &checkstdineof,     2,
  1645.     'S', 'V', "CHECKFILESEEK",   (anyptr) &checkfileseek,     2,
  1646. }
  1647. #endif /* define_parameters */
  1648.     ;
  1649.  
  1650.  
  1651. #undef extern
  1652.  
  1653.  
  1654. #ifdef define_parameters
  1655.   int numparams = sizeof(rctable) / sizeof(struct rcstruct);
  1656.   Strlist *rcprevvalues[sizeof(rctable) / sizeof(struct rcstruct)];
  1657. #else
  1658.   extern int numparams;
  1659.   extern Strlist *rcprevvalues[];
  1660. #endif /* define_parameters */
  1661.  
  1662.  
  1663.  
  1664. /* Global variables: */
  1665.  
  1666. #ifdef define_globals
  1667. # define extern
  1668. #endif /* define_globals */
  1669.  
  1670.  
  1671. extern char *charname, *ucharname, *scharname, *integername;
  1672. extern long min_schar, max_schar, max_uchar;
  1673. extern long min_sshort, max_sshort, max_ushort;
  1674.  
  1675. extern char *alloctemp;
  1676. extern short error_crash;
  1677. extern int total_bytes, total_exprs, total_meanings, total_strings;
  1678. extern int total_symbols, total_types, total_stmts, total_strlists;
  1679. extern int total_literals, total_ctxstacks, total_tempvars, total_inprecs;
  1680. extern int total_parens, total_ptrdescs, total_misc;
  1681. extern int final_bytes, final_exprs, final_meanings, final_strings;
  1682. extern int final_symbols, final_types, final_stmts, final_strlists;
  1683. extern int final_literals, final_ctxstacks, final_tempvars, final_inprecs;
  1684. extern int final_parens, final_ptrdescs, final_misc;
  1685.  
  1686. extern char *infname, *outfname, *codefname, *hdrfname;
  1687. extern char *requested_module;
  1688. extern FILE *inf, *outf, *codef, *hdrf, *logf;
  1689. extern short setup_complete, found_module;
  1690. extern short regression, verbose, conserve_mem;
  1691. extern int inf_lnum, inf_ltotal;
  1692.  
  1693. extern int outindent, outputmode;
  1694. extern int outf_lnum;
  1695. extern short dontbreaklines;
  1696.  
  1697. extern Token curtok;
  1698. extern char curtokbuf[256], curtokcase[256];
  1699. extern char *inbufptr;
  1700. extern int inbufindent;
  1701. extern long curtokint;
  1702. extern Symbol *curtoksym;
  1703. extern Meaning *curtokmeaning;
  1704. extern Strlist *curcomments;
  1705. extern Strlist **keepingstrlist;
  1706. extern short ignore_directives, skipping_module;
  1707. extern short C_lex;
  1708. extern char sysprog_flag, partial_eval_flag, iocheck_flag;
  1709. extern char range_flag, ovflcheck_flag, stackcheck_flag;
  1710. extern short switch_strpos;
  1711. extern int fixedflag;
  1712. extern int numimports;
  1713. extern Strlist *tempoptionlist;
  1714. extern long curserial, serialcount;
  1715. extern int notephase;
  1716. extern Strlist *permimports;
  1717. extern int permflag;
  1718.  
  1719. #define SYMHASHSIZE 293
  1720. extern Symbol *(symtab[SYMHASHSIZE]);
  1721. extern short partialdump;
  1722.  
  1723. #define MAXWITHS 100
  1724. extern int withlevel;
  1725. extern Type *withlist[MAXWITHS];
  1726. extern Expr *withexprs[MAXWITHS];
  1727.  
  1728. extern Token blockkind;
  1729. extern Meaning *curctx, *curctxlast, *nullctx;
  1730.  
  1731. extern int fixexpr_tryblock;
  1732. extern short fixexpr_tryflag;
  1733.  
  1734. extern Type *tp_integer, *tp_char, *tp_boolean, *tp_real, *tp_longreal;
  1735. extern Type *tp_anyptr, *tp_jmp_buf, *tp_schar, *tp_uchar, *tp_charptr;
  1736. extern Type *tp_int, *tp_sshort, *tp_ushort, *tp_abyte, *tp_sbyte, *tp_ubyte;
  1737. extern Type *tp_void, *tp_str255, *tp_strptr, *tp_text, *tp_bigtext;
  1738. extern Type *tp_unsigned, *tp_uint, *tp_sint, *tp_smallset, *tp_proc;
  1739. extern Meaning *mp_string, *mp_true, *mp_false;
  1740. extern Meaning *mp_input, *mp_output, *mp_stderr;
  1741. extern Meaning *mp_maxint, *mp_minint, *mp_escapecode, *mp_ioresult;
  1742. extern Meaning *mp_uchar, *mp_schar, *mp_unsigned, *mp_uint;
  1743. extern Meaning *mp_str_hp, *mp_str_turbo;
  1744. extern Meaning *mp_val_modula, *mp_val_turbo;
  1745. extern Meaning *mp_blockread_ucsd, *mp_blockread_turbo;
  1746. extern Meaning *mp_blockwrite_ucsd, *mp_blockwrite_turbo;
  1747. extern Meaning *mp_dec_dec, *mp_dec_turbo;
  1748. extern Expr *ex_input, *ex_output;
  1749. extern Strlist *attrlist;
  1750.  
  1751.  
  1752. #ifndef define_globals
  1753. # undef extern
  1754. #endif
  1755.  
  1756.  
  1757.  
  1758.  
  1759. /* Function declarations are created automatically by "makeproto" */
  1760.  
  1761. #include "p2c.hdrs"
  1762.  
  1763. #include "p2c.proto"
  1764.  
  1765.  
  1766.  
  1767. /* Our library omits declarations for these functions! */
  1768.  
  1769. int link           PP( (char *, char *) );
  1770. int unlink         PP( (char *) );
  1771.  
  1772.  
  1773.  
  1774. #define minspcthresh ((minspacingthresh >= 0) ? minspacingthresh : minspacing)
  1775.  
  1776. #define delfreearg(ex, n) freeexpr((*(ex))->args[n]), deletearg(ex, n)
  1777. #define delsimpfreearg(ex, n) freeexpr((*(ex))->args[n]), delsimparg(ex, n)
  1778.  
  1779. #define swapexprs(a,b) do {register Expr *t=(a);(a)=(b);(b)=(t);} while (0)
  1780. #define swapstmts(a,b) do {register Stmt *t=(a);(a)=(b);(b)=(t);} while (0)
  1781.  
  1782. #define CHECKORDEXPR(ex,v) ((ex)->kind==EK_CONST ? (ex)->val.i - (v) : -2)
  1783.  
  1784. #define FCheck(flag)  ((flag) == 1 || (!iocheck_flag && (flag)))
  1785. #define checkeof(fex)  (isvar(fex, mp_input) ? FCheck(checkstdineof)  \
  1786.                          : FCheck(checkfileeof))
  1787.  
  1788.  
  1789. #ifdef TEST_MALLOC   /* Memory testing */
  1790.  
  1791. #define ALLOC(N,TYPE,NAME) \
  1792.     (TYPE *) test_malloc((unsigned)((N)*sizeof(TYPE)),  \
  1793.              &__CAT__(total_,NAME), &__CAT__(final_,NAME))
  1794.  
  1795. #define ALLOCV(N,TYPE,NAME) \
  1796.     (TYPE *) test_malloc((unsigned)(N),  \
  1797.              &__CAT__(total_,NAME), &__CAT__(final_,NAME))
  1798.  
  1799. #define REALLOC(P,N,TYPE) \
  1800.     (TYPE *) test_realloc((char *)(P), (unsigned)((N)*sizeof(TYPE)))
  1801.  
  1802. #define FREE(P) test_free((char*)(P))
  1803.  
  1804. #else  /* not TEST_MALLOC */
  1805.  
  1806. /* If p2c always halts immediately with an out-of-memory error, try
  1807.    recompiling all modules with BROKEN_OR defined. */
  1808. #ifdef BROKEN_OR
  1809.  
  1810. #define ALLOC(N,TYPE,NAME) \
  1811.     ((alloctemp = malloc((unsigned)((N)*sizeof(TYPE)))), \
  1812.      (alloctemp ? (TYPE *) alloctemp : (TYPE *) outmem()))
  1813.  
  1814. #define ALLOCV(N,TYPE,NAME) \
  1815.     ((alloctemp = malloc((unsigned)(N))), \
  1816.      (alloctemp ? (TYPE *) alloctemp : (TYPE *) outmem()))
  1817.  
  1818. #define REALLOC(P,N,TYPE) \
  1819.     ((alloctemp = realloc((char*)(P), (unsigned)((N)*sizeof(TYPE)))), \
  1820.      (alloctemp ? (TYPE *) alloctemp : (TYPE *) outmem()))
  1821.  
  1822. #define FREE(P) free((char*)(P))
  1823.  
  1824. #else  /* not BROKEN_OR */
  1825.  
  1826. #define ALLOC(N,TYPE,NAME) \
  1827.     ((alloctemp = malloc((unsigned)((N)*sizeof(TYPE)))) || outmem(), \
  1828.      (TYPE *) alloctemp)
  1829.  
  1830. #define ALLOCV(N,TYPE,NAME) \
  1831.     ((alloctemp = malloc((unsigned)(N))) || outmem(), \
  1832.      (TYPE *) alloctemp)
  1833.  
  1834. #define REALLOC(P,N,TYPE) \
  1835.     ((alloctemp = realloc((char*)(P), (unsigned)((N)*sizeof(TYPE)))) || outmem(), \
  1836.      (TYPE *) alloctemp)
  1837.  
  1838. #define FREE(P) free((char*)(P))
  1839.  
  1840. #endif  /* BROKEN_OR */
  1841. #endif  /* TEST_MALLOC */
  1842.  
  1843.  
  1844. #define MIN(a,b) ((a) < (b) ? (a) : (b))
  1845. #define MAX(a,b) ((a) > (b) ? (a) : (b))
  1846.  
  1847.  
  1848.  
  1849. #ifdef toupper
  1850. # undef toupper
  1851. # undef tolower
  1852. # define toupper(c)   my_toupper(c)
  1853. # define tolower(c)   my_tolower(c)
  1854. #endif
  1855.  
  1856. #ifndef _toupper
  1857. # if 'A' == 65 && 'a' == 97
  1858. #  define _toupper(c)  ((c)-'a'+'A')
  1859. #  define _tolower(c)  ((c)-'A'+'a')
  1860. # else
  1861. #  ifdef toupper
  1862. #   undef toupper   /* hope these are shadowing real functions, */
  1863. #   undef tolower   /* because my_toupper calls _toupper! */
  1864. #  endif
  1865. #  define _toupper(c)  toupper(c)
  1866. #  define _tolower(c)  tolower(c)
  1867. # endif
  1868. #endif
  1869.  
  1870.  
  1871.  
  1872.  
  1873. /* End. */
  1874.  
  1875.