ack/lang/cem/cemcom/options.c

348 lines
6.8 KiB
C
Raw Normal View History

/*
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
* See the copyright notice in the ACK home directory, in the file "Copyright".
*/
1986-03-10 13:07:55 +00:00
/* $Header$ */
/* U S E R O P T I O N - H A N D L I N G */
#include "lint.h"
#include "botch_free.h"
#include <alloc.h>
#include "nofloat.h"
1986-03-10 13:07:55 +00:00
#include "nopp.h"
#include "idfsize.h"
#include "nobitfield.h"
#include "class.h"
#include "macro.h"
#include "idf.h"
#include "arith.h"
#include "sizes.h"
#include "align.h"
#include "use_tmp.h"
#include "dataflow.h"
1987-03-25 23:14:43 +00:00
#include "noRoption.h"
1986-03-10 13:07:55 +00:00
#ifndef NOPP
extern char **inctable;
1986-03-10 13:07:55 +00:00
extern int inc_pos;
extern int inc_max;
extern int inc_total;
1986-03-10 13:07:55 +00:00
#endif NOPP
char options[128]; /* one for every char */
#ifdef LINT
char loptions[128]; /* one for every char */
#endif LINT
1986-03-10 13:07:55 +00:00
extern int idfsize;
1988-09-16 23:19:50 +00:00
static int txt2int();
1986-03-10 13:07:55 +00:00
do_option(text)
char *text;
{
register char opt;
1988-09-16 23:19:50 +00:00
next_option: /* to allow combined one-char options */
switch (opt = *text++) {
1986-03-10 13:07:55 +00:00
1988-09-16 23:19:50 +00:00
case 0: /* to end the goto next_option loop */
break;
1986-03-10 13:07:55 +00:00
default:
#ifndef LINT
fatal("illegal option: %c", opt);
#else LINT
warning("illegal option: %c", opt);
#endif LINT
1988-08-19 13:55:22 +00:00
break;
1988-09-16 23:19:50 +00:00
case '-':
1988-09-16 23:19:50 +00:00
options[*text++] = 1; /* flags, debug options etc. */
goto next_option;
1986-03-10 13:07:55 +00:00
#ifndef LINT
1988-08-19 13:55:22 +00:00
#ifdef DATAFLOW
case 'd':
1988-08-19 13:55:22 +00:00
#endif DATAFLOW
case 'p': /* procentry/procexit */
case 'L' : /* no fil/lin */
case 'n': /* use no registers */
case 'w': /* no warnings will be given */
options[opt] = 1;
1988-09-16 23:19:50 +00:00
goto next_option;
#endif LINT
#ifdef LINT
case 'h': /* heuristic tests */
case 'v': /* no complaints about unused arguments */
case 'a': /* check long->int int->long conversions */
case 'b': /* don't report unreachable break-statements */
case 'x': /* complain about unused extern declared variables */
case 'u': /* no "used but not defined"; for pass 2 */
1988-11-03 15:18:46 +00:00
case 'L': /* lintlibrary */
loptions[opt] = 1;
goto next_option;
#endif LINT
case 'R': /* strict version */
#ifndef NOROPTION
options[opt] = 1;
#else NOROPTION
1987-03-25 23:14:43 +00:00
warning("-R option not implemented");
#endif NOROPTION
1988-09-16 23:19:50 +00:00
goto next_option;
1988-08-19 13:55:22 +00:00
#ifdef ___XXX___
deleted, is now a debug-flag
1986-03-10 13:07:55 +00:00
case 'C' : /* E option + comment output */
1988-08-19 13:55:22 +00:00
#ifndef NOPP
1986-03-10 13:07:55 +00:00
options['E'] = 1;
warning("-C: comment is not output");
#else NOPP
warning("-C option ignored");
1988-08-19 13:55:22 +00:00
#endif NOPP
1986-03-10 13:07:55 +00:00
break;
1988-08-19 13:55:22 +00:00
#endif ___XXX___
1986-03-10 13:07:55 +00:00
case 'D' : { /* -Dname : predefine name */
#ifndef NOPP
register char *cp = text, *name, *mactext;
if (class(*cp) != STIDF) {
error("identifier missing in -D%s", text);
break;
}
name = cp;
while (*cp && in_idf(*cp)) {
++cp;
}
if (!*cp) { /* -Dname */
mactext = "1";
}
else
if (*cp == '=') { /* -Dname=text */
*cp++ = '\0'; /* end of name */
mactext = cp;
}
else { /* -Dname?? */
error("malformed option -D%s", text);
break;
}
macro_def(str2idf(name), mactext, -1, strlen(mactext),
NOFLAG);
#else NOPP
warning("-D option ignored");
#endif NOPP
break;
}
#ifdef ___XXX___
deleted, is now a debug-flag
1986-03-10 13:07:55 +00:00
case 'E' : /* run preprocessor only, with #<int> */
#ifndef NOPP
options['E'] = 1;
#else NOPP
warning("-E option ignored");
#endif NOPP
break;
#endif ___XXX___
1986-03-10 13:07:55 +00:00
case 'I' : /* -Ipath : insert "path" into include list */
#ifndef NOPP
if (*text) {
int i;
1986-03-10 13:07:55 +00:00
register char *new = text;
if (++inc_total > inc_max) {
char **n = (char **)
Malloc((10+inc_max)*sizeof(char *));
for (i = 0; i < inc_max; i++) {
n[i] = inctable[i];
}
free((char *) inctable);
inctable = n;
inc_max += 10;
}
i = inc_pos++;
1986-03-10 13:07:55 +00:00
while (new) {
1987-03-25 23:14:43 +00:00
char *tmp = inctable[i];
1986-03-10 13:07:55 +00:00
inctable[i++] = new;
new = tmp;
}
}
else inctable[inc_pos] = 0;
1986-03-10 13:07:55 +00:00
#else NOPP
warning("-I option ignored");
#endif NOPP
break;
case 'M': /* maximum identifier length */
idfsize = txt2int(&text);
if (*text || idfsize <= 0)
fatal("malformed -M option");
if (idfsize > IDFSIZE)
fatal("maximum identifier length is %d", IDFSIZE);
break;
#ifdef ___XXX___
deleted, is now a debug-flag
1986-03-10 13:07:55 +00:00
case 'P' : /* run preprocessor stand-alone, without #'s */
#ifndef NOPP
options['E'] = 1;
options['P'] = 1;
#else NOPP
warning("-P option ignored");
#endif NOPP
break;
#endif ___XXX___
#ifdef LINT
case 'S' : { /* -Sint : static scope number for lint */
extern int stat_number;
stat_number = txt2int(&text);
break;
}
#endif LINT
case 'T' : {
#ifdef USE_TMP
extern char *C_tmpdir;
if (*text)
C_tmpdir = text;
else
C_tmpdir = ".";
#else USE_TMP
warning("-T option ignored");
#endif USE_TMP
break;
}
1986-03-10 13:07:55 +00:00
case 'U' : { /* -Uname : undefine predefined */
#ifndef NOPP
1987-03-25 23:14:43 +00:00
register struct idf *idef;
1986-03-10 13:07:55 +00:00
if (*text) {
if ((idef = str2idf(text))->id_macro) {
free_macro(idef->id_macro);
idef->id_macro = (struct macro *) 0;
}
}
#else NOPP
warning("-U option ignored");
#endif NOPP
break;
}
#ifndef LINT
1986-03-10 13:07:55 +00:00
case 'V' : /* set object sizes and alignment requirements */
1987-03-25 23:14:43 +00:00
#ifdef NOCROSS
warning("-V option ignored");
break;
#else NOCROSS
1986-03-10 13:07:55 +00:00
{
register arith sz, algn;
1986-03-10 13:07:55 +00:00
char c;
while (c = *text++) {
sz = txt2int(&text);
algn = 0;
1986-03-10 13:07:55 +00:00
if (*text == '.') {
text++;
algn = txt2int(&text);
1986-03-10 13:07:55 +00:00
}
switch (c) {
case 's': /* short */
if (sz != (arith)0)
short_size = sz;
if (algn != 0)
short_align = algn;
1986-03-10 13:07:55 +00:00
break;
case 'w': /* word */
if (sz != (arith)0)
dword_size = (word_size = sz) << 1;
if (algn != 0)
word_align = algn;
1986-03-10 13:07:55 +00:00
break;
case 'i': /* int */
if (sz != (arith)0)
int_size = sz;
if (algn != 0)
int_align = algn;
1986-03-10 13:07:55 +00:00
break;
case 'l': /* long */
if (sz != (arith)0)
long_size = sz;
if (algn != 0)
long_align = algn;
1986-03-10 13:07:55 +00:00
break;
case 'f': /* float */
#ifndef NOFLOAT
if (sz != (arith)0)
float_size = sz;
if (algn != 0)
float_align = algn;
#endif NOFLOAT
1986-03-10 13:07:55 +00:00
break;
case 'd': /* double */
#ifndef NOFLOAT
if (sz != (arith)0)
double_size = sz;
if (algn != 0)
double_align = algn;
#endif NOFLOAT
1986-03-10 13:07:55 +00:00
break;
case 'p': /* pointer */
if (sz != (arith)0)
pointer_size = sz;
if (algn != 0)
pointer_align = algn;
1986-03-10 13:07:55 +00:00
break;
case 'r': /* adjust bitfields right */
#ifndef NOBITFIELD
options['r'] = 1;
#else NOBITFIELD
warning("bitfields are not implemented");
#endif NOBITFIELD
break;
case 'S': /* initial struct alignment */
if (sz != (arith)0)
struct_align = sz;
1986-03-10 13:07:55 +00:00
break;
case 'U': /* initial union alignment */
if (sz != (arith)0)
union_align = sz;
1986-03-10 13:07:55 +00:00
break;
default:
error("-V: bad type indicator %c\n", c);
}
}
break;
}
1987-03-25 23:14:43 +00:00
#endif NOCROSS
#endif LINT
1986-03-10 13:07:55 +00:00
}
}
1988-09-16 23:19:50 +00:00
static int
1986-03-10 13:07:55 +00:00
txt2int(tp)
1987-03-25 23:14:43 +00:00
register char **tp;
1986-03-10 13:07:55 +00:00
{
/* the integer pointed to by *tp is read, while increasing
*tp; the resulting value is yielded.
*/
register int val = 0, ch;
1986-03-10 13:07:55 +00:00
while (ch = **tp, ch >= '0' && ch <= '9') {
val = val * 10 + ch - '0';
(*tp)++;
}
return val;
}