X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/mLib/blobdiff_plain/c846879ccf3e86ea293c157f4aa2ff8716fb5b4c..f4d2cec8cdfb26c8bcdd8694aa3e791cbd439212:/testrig.c diff --git a/testrig.c b/testrig.c index 2f40b5b..95aca95 100644 --- a/testrig.c +++ b/testrig.c @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: testrig.c,v 1.2 1999/05/05 18:50:31 mdw Exp $ + * $Id: testrig.c,v 1.5 1999/05/21 22:14:30 mdw Exp $ * * Generic test driver * @@ -22,13 +22,25 @@ * GNU Library General Public License for more details. * * You should have received a copy of the GNU Library General Public - * License along with mLib; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * License along with mLib; if not, write to the Free + * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, + * MA 02111-1307, USA. */ /*----- Revision history --------------------------------------------------* * * $Log: testrig.c,v $ + * Revision 1.5 1999/05/21 22:14:30 mdw + * Take advantage of the new dynamic string macros. + * + * Revision 1.4 1999/05/19 19:02:17 mdw + * Aesthetic changes: fix spelling of `initialize'; use uppercase token + * constants; abandon old double-underscore convention for internal + * functions and variables. + * + * Revision 1.3 1999/05/06 19:51:35 mdw + * Reformatted the LGPL notice a little bit. + * * Revision 1.2 1999/05/05 18:50:31 mdw * Change licensing conditions to LGPL. * @@ -52,16 +64,16 @@ /*----- Static variables --------------------------------------------------*/ -static dstr test__tok; +static dstr tok; enum { - tok_eof = 0x100, - tok_word + TOK_EOF = 0x100, + TOK_WORD }; /*----- Main code ---------------------------------------------------------*/ -/* --- @test__decode@ --- * +/* --- @decode@ --- * * * Arguments: @int tok@ = token type to decode * @@ -70,24 +82,24 @@ enum { * Use: Produces a readable representation of a token. */ -static const char *test__decode(int tok) +static const char *decode(int t) { static char buf[4]; - switch (tok) { - case tok_eof: + switch (t) { + case TOK_EOF: return (""); - case tok_word: - return (test__tok.buf); + case TOK_WORD: + return (tok.buf); default: - buf[0] = tok; + buf[0] = t; buf[1] = 0; return (buf); } return (""); } -/* --- @test__gettok@ --- * +/* --- @gettok@ --- * * * Arguments: @FILE *fp@ = file handle to read from * @@ -96,13 +108,13 @@ static const char *test__decode(int tok) * Use: Reads a token from the input stream. */ -static int test__gettok(FILE *fp) +static int gettok(FILE *fp) { int ch; /* --- Clear the token accumulator --- */ - dstr_reset(&test__tok); + DRESET(&tok); /* --- Prime the lookahead character --- */ @@ -127,7 +139,7 @@ again: /* --- End of file --- */ case EOF: - return (tok_eof); + return (TOK_EOF); /* --- Quote characters --- */ @@ -146,10 +158,10 @@ again: if (ch == EOF) ch = '\\'; } - DPUTC(&test__tok, ch); + DPUTC(&tok, ch); } - DPUTZ(&test__tok); - return (tok_word); + DPUTZ(&tok); + return (TOK_WORD); } /* --- Anything else is either a word or self-delimiting --- */ @@ -157,7 +169,7 @@ again: default: if (isalnum((unsigned char)ch)) { for (;;) { - DPUTC(&test__tok, ch); + DPUTC(&tok, ch); ch = getc(fp); if (ch == EOF || ch == ';' || @@ -171,8 +183,8 @@ again: } } ungetc(ch, fp); - DPUTZ(&test__tok); - return (tok_word); + DPUTZ(&tok); + return (TOK_WORD); } else return (ch); } @@ -215,7 +227,7 @@ static void cvt_string(const char *s, dstr *d) static void dump_string(dstr *d, FILE *fp) { - dstr_write(d, fp); + DWRITE(d, fp); } test_type type_string = { cvt_string, dump_string }; @@ -259,12 +271,12 @@ void test_run(int argc, char *argv[], int fail = 0, ok = 1; int sofar = 0; - /* --- Silly bits of initialisation --- */ + /* --- Silly bits of initialization --- */ ego(argv[0]); for (i = 0; i < TEST_FIELDMAX; i++) - dstr_create(&dv[i]); + DCREATE(&dv[i]); /* --- Parse command line arguments --- */ @@ -312,31 +324,31 @@ void test_run(int argc, char *argv[], die(1, "couldn't open test vector file `%s': %s", vec, strerror(errno)); for (;;) { - int tok = test__gettok(fp); + int t = gettok(fp); /* --- This is a reasonable place to stop --- */ - if (tok == tok_eof) + if (t == TOK_EOF) break; /* --- Pick out the chunk name --- */ - if (tok != tok_word) - die(1, "expected ; found `%s'", test__decode(tok)); + if (t != TOK_WORD) + die(1, "expected ; found `%s'", decode(t)); /* --- Find the right chunk block --- */ for (cch = chunk; ; cch++) { if (!cch->name) goto skip_chunk; - if (strcmp(test__tok.buf, cch->name) == 0) + if (strcmp(tok.buf, cch->name) == 0) break; } /* --- Past the open brace to the first chunk --- */ - if ((tok = test__gettok(fp)) != '{') - die(1, "expected '{'; found `%s'", test__decode(tok)); + if ((t = gettok(fp)) != '{') + die(1, "expected '{'; found `%s'", decode(t)); /* --- Start on the test data now --- */ @@ -346,27 +358,27 @@ void test_run(int argc, char *argv[], ok = 1; for (;;) { - tok = test__gettok(fp); + t = gettok(fp); /* --- Accept a close brace --- */ - if (tok == '}') + if (t == '}') break; /* --- Otherwise I expect a list of words --- */ for (i = 0; cch->f[i]; i++) { - dstr_reset(&dv[i]); - if (tok != tok_word) - die(1, "expected ; found `%s'", test__decode(tok)); - cch->f[i]->cvt(test__tok.buf, &dv[i]); - tok = test__gettok(fp); + DRESET(&dv[i]); + if (t != TOK_WORD) + die(1, "expected ; found `%s'", decode(t)); + cch->f[i]->cvt(tok.buf, &dv[i]); + t = gettok(fp); } /* --- And a terminating semicolon --- */ - if (tok != ';') - die(1, "expected `;'; found `%s'", test__decode(tok)); + if (t != ';') + die(1, "expected `;'; found `%s'", decode(t)); /* --- Run the test code --- */ @@ -385,16 +397,16 @@ void test_run(int argc, char *argv[], continue; skip_chunk: - if ((tok = test__gettok(fp)) != '{') - die(1, "expected '{'; found `%s'", test__decode(tok)); + if ((t = gettok(fp)) != '{') + die(1, "expected '{'; found `%s'", decode(t)); for (;;) { - tok = test__gettok(fp); - if (tok == '}') + t = gettok(fp); + if (t == '}') break; - while (tok == tok_word) - tok = test__gettok(fp); - if (tok != ';') - die(1, "expected `;'; found `%s'", test__decode(tok)); + while (t == TOK_WORD) + t = gettok(fp); + if (t != ';') + die(1, "expected `;'; found `%s'", decode(t)); } }