Initial revision
This commit is contained in:
249
emtest/select.c
Normal file
249
emtest/select.c
Normal file
@@ -0,0 +1,249 @@
|
||||
/*
|
||||
* (c) copyright 1983 by the Vrije Universiteit, Amsterdam, The Netherlands.
|
||||
*
|
||||
* This product is part of the Amsterdam Compiler Kit.
|
||||
*
|
||||
* Permission to use, sell, duplicate or disclose this software must be
|
||||
* obtained in writing. Requests for such permissions may be sent to
|
||||
*
|
||||
* Dr. Andrew S. Tanenbaum
|
||||
* Wiskundig Seminarium
|
||||
* Vrije Universiteit
|
||||
* Postbox 7161
|
||||
* 1007 MC Amsterdam
|
||||
* The Netherlands
|
||||
*
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <assert.h>
|
||||
#include <signal.h>
|
||||
|
||||
#define LINSIZ 100
|
||||
|
||||
int sigs[] = {
|
||||
SIGHUP,
|
||||
SIGINT,
|
||||
SIGQUIT,
|
||||
SIGTERM,
|
||||
0
|
||||
};
|
||||
|
||||
char *prog;
|
||||
char line[LINSIZ];
|
||||
int nlocals = 0;
|
||||
int nhol = 0;
|
||||
int nerrors = 0;
|
||||
int oknum = 2;
|
||||
int fflag = 1;
|
||||
int low = 0;
|
||||
int high = 999;
|
||||
|
||||
FILE *file1;
|
||||
FILE *file2;
|
||||
FILE *file3;
|
||||
char name1[] = "/usr/tmp/f1XXXXXX";
|
||||
char name2[] = "/usr/tmp/f2XXXXXX";
|
||||
char name3[] = "/usr/tmp/f3XXXXXX";
|
||||
|
||||
stop() {
|
||||
unlink(name1);
|
||||
unlink(name2);
|
||||
unlink(name3);
|
||||
exit(nerrors);
|
||||
}
|
||||
|
||||
main(argc,argv) char **argv; {
|
||||
register *p;
|
||||
register char *s;
|
||||
|
||||
prog = *argv++; --argc;
|
||||
mktemp(name1);
|
||||
mktemp(name2);
|
||||
mktemp(name3);
|
||||
for (p = sigs; *p; p++)
|
||||
if (signal(*p, stop) == SIG_IGN)
|
||||
signal(*p, SIG_IGN);
|
||||
while (argc > 0 && argv[0][0] == '-') {
|
||||
switch (argv[0][1]) {
|
||||
case 'f':
|
||||
fflag ^= 1;
|
||||
break;
|
||||
case '0': case '1': case '2': case '3': case '4':
|
||||
case '5': case '6': case '7': case '8': case '9':
|
||||
high = atoi(&argv[0][1]);
|
||||
break;
|
||||
default:
|
||||
usage();
|
||||
break;
|
||||
}
|
||||
argc--;
|
||||
argv++;
|
||||
}
|
||||
if (argc > 0 && argv[0][0] >= '0' && argv[0][0] <= '9') {
|
||||
s = argv[0];
|
||||
do
|
||||
low = low*10 + *s++ - '0';
|
||||
while (*s >= '0' && *s <= '9');
|
||||
if (*s == 0)
|
||||
high = low;
|
||||
else if (*s++ == '-') {
|
||||
high = atoi(s);
|
||||
if (high == 0)
|
||||
high = 999;
|
||||
} else
|
||||
fatal("bad range %s", argv[0]);
|
||||
argc--;
|
||||
argv++;
|
||||
}
|
||||
if (argc > 1)
|
||||
usage();
|
||||
if (argc == 1 && freopen(argv[0], "r", stdin) == NULL)
|
||||
fatal("cannot open %s", argv[0]);
|
||||
if ((file1 = fopen(name1, "w")) == NULL)
|
||||
fatal("cannot create %s", name1);
|
||||
if ((file2 = fopen(name2, "w")) == NULL)
|
||||
fatal("cannot create %s", name2);
|
||||
if ((file3 = fopen(name3, "w")) == NULL)
|
||||
fatal("cannot create %s", name3);
|
||||
if (getline())
|
||||
while (select())
|
||||
;
|
||||
fclose(file1);
|
||||
fclose(file2);
|
||||
fclose(file3);
|
||||
combine();
|
||||
stop();
|
||||
}
|
||||
|
||||
select() {
|
||||
register FILE *f;
|
||||
int i;
|
||||
|
||||
if (sscanf(line, "TEST %d", &i) != 1)
|
||||
fatal("bad test identification(%s)", line);
|
||||
if (i < low || i > high) {
|
||||
while (getline())
|
||||
if (line[0] == 'T')
|
||||
return(1);
|
||||
return(0);
|
||||
}
|
||||
fprintf(file2, "; %s\n", line);
|
||||
if (fflag) {
|
||||
fprintf(file1, ".%03d\n", i);
|
||||
fprintf(file1, " con \"tst%03d\"\n", i);
|
||||
fprintf(file2, " fil .%03d\n", i);
|
||||
}
|
||||
f = file1;
|
||||
while (getline()) {
|
||||
switch (line[0]) {
|
||||
case 'T':
|
||||
return(1);
|
||||
case 'M':
|
||||
if (sscanf(line, "MAIN%d", &i) != 1 || i%4 != 0)
|
||||
break;
|
||||
if (i > nlocals)
|
||||
nlocals = i;
|
||||
f = file2;
|
||||
continue;
|
||||
case 'P':
|
||||
if (strcmp(line, "PROC") != 0)
|
||||
break;
|
||||
f = file3;
|
||||
continue;
|
||||
case 'H':
|
||||
if (f != file1 ||
|
||||
sscanf(line, "HOL%d", &i) != 1 ||
|
||||
i%4 != 0)
|
||||
break;
|
||||
if (i > nhol)
|
||||
nhol = i;
|
||||
continue;
|
||||
case 'O':
|
||||
if (strcmp(line, "OK") != 0)
|
||||
break;
|
||||
fprintf(f, " lin %d\n nop\n", oknum++);
|
||||
continue;
|
||||
case 'E':
|
||||
if (f != file3 || strcmp(line, "ERRLAB") != 0)
|
||||
break;
|
||||
fprintf(f, "1\n lin 1\n nop\n loc 1\n loc 1\n mon\n");
|
||||
continue;
|
||||
default:
|
||||
putline(f);
|
||||
continue;
|
||||
}
|
||||
fatal("bad line (%s)", line);
|
||||
}
|
||||
return(0);
|
||||
}
|
||||
|
||||
combine() {
|
||||
|
||||
printf("#define WS EM_WSIZE\n");
|
||||
printf("#define PS EM_PSIZE\n");
|
||||
printf("#include \"test.h\"\n");
|
||||
printf(" mes 2,WS,PS\n");
|
||||
printf(" mes 1\n");
|
||||
printf(" mes 4,300\n");
|
||||
if (nhol)
|
||||
printf(" hol %d,0,0\n", nhol);
|
||||
copy(name1);
|
||||
printf(" exp $m_a_i_n\n");
|
||||
printf(" pro $m_a_i_n,%d\n", nlocals);
|
||||
printf(" loc 123\n");
|
||||
printf(" loc -98\n");
|
||||
copy(name2);
|
||||
printf(" loc -98\n");
|
||||
printf(" bne *1\n");
|
||||
printf(" loc 123\n");
|
||||
printf(" bne *1\n");
|
||||
printf(" lin 0\n");
|
||||
printf(" nop\n");
|
||||
printf(" loc 0\n");
|
||||
printf(" ret WS\n");
|
||||
printf("1\n");
|
||||
printf(" lin 1\n");
|
||||
printf(" nop\n");
|
||||
printf(" loc 1\n");
|
||||
printf(" ret WS\n");
|
||||
printf(" end\n");
|
||||
copy(name3);
|
||||
}
|
||||
|
||||
copy(s) char *s; {
|
||||
if (freopen(s, "r", stdin) == NULL)
|
||||
fatal("cannot reopen %s", s);
|
||||
while (getline())
|
||||
putline(stdout);
|
||||
}
|
||||
|
||||
getline() {
|
||||
register len;
|
||||
|
||||
if (fgets(line, LINSIZ, stdin) == NULL)
|
||||
return(0);
|
||||
len = strlen(line);
|
||||
if (line[len-1] != '\n')
|
||||
fatal("line too long(%s)", line);
|
||||
line[len-1] = 0;
|
||||
return(1);
|
||||
}
|
||||
|
||||
putline(f) FILE *f; {
|
||||
fprintf(f, "%s\n", line);
|
||||
}
|
||||
|
||||
fatal(s, a1, a2, a3, a4) char *s; {
|
||||
fprintf(stderr, "%s: ", prog);
|
||||
fprintf(stderr, s, a1, a2, a3, a4);
|
||||
fprintf(stderr, " (fatal)\n");
|
||||
nerrors++;
|
||||
stop();
|
||||
}
|
||||
|
||||
usage() {
|
||||
fprintf(stderr, "usage: %s -f [[low]-[high]] [testcollection]\n", prog);
|
||||
nerrors++;
|
||||
stop();
|
||||
}
|
||||
Reference in New Issue
Block a user