/*-
* This code contains changes by
* Gunnar Ritter, Freiburg i. Br., Germany, 2002. All rights reserved.
*
* Conditions 1, 2, and 4 and the no-warranty notice below apply
* to these changes.
*
*
* Copyright (c) 1991
* The Regents of the University of California. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by the University of
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
*
* Copyright(C) Caldera International Inc. 2001-2002. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* Redistributions of source code and documentation must retain the
* above copyright notice, this list of conditions and the following
* disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed or owned by Caldera
* International, Inc.
* Neither the name of Caldera International, Inc. nor the names of
* other contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* USE OF THE SOFTWARE PROVIDED FOR UNDER THIS LICENSE BY CALDERA
* INTERNATIONAL, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL CALDERA INTERNATIONAL, INC. BE
* LIABLE FOR ANY DIRECT, INDIRECT INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifdef notdef
char copyright[] =
"Copyright (c) 1991 The Regents of the University of California.\n\
All rights reserved.\n";
#endif
/* from 4.4BSD /usr/src/old/awk/proc.c 4.4 (Berkeley) 4/17/91 */
/* Sccsid @(#)proc.c 1.8 (gritter) 12/25/06> */
#include "awk.h"
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct xx
{ int token;
const char *name;
const char *pname;
} proc[] = {
{ PROGRAM, "program", NULL},
{ BOR, "boolop", " || "},
{ AND, "boolop", " && "},
{ NOT, "boolop", " !"},
{ NE, "relop", " != "},
{ EQ, "relop", " == "},
{ LE, "relop", " <= "},
{ LT, "relop", " < "},
{ GE, "relop", " >= "},
{ GT, "relop", " > "},
{ ARRAY, "array", NULL},
{ INDIRECT, "indirect", "$("},
{ SUBSTR, "substr", "substr"},
{ INDEX, "sindex", "sindex"},
{ SPRINTF, "awsprintf", "sprintf "},
{ ADD, "arith", " + "},
{ MINUS, "arith", " - "},
{ MULT, "arith", " * "},
{ DIVIDE, "arith", " / "},
{ MOD, "arith", " % "},
{ UMINUS, "arith", " -"},
{ PREINCR, "incrdecr", "++"},
{ POSTINCR, "incrdecr", "++"},
{ PREDECR, "incrdecr", "--"},
{ POSTDECR, "incrdecr", "--"},
{ CAT, "cat", " "},
{ PASTAT, "pastat", NULL},
{ PASTAT2, "dopa2", NULL},
{ MATCH, "matchop", " ~ "},
{ NOTMATCH, "matchop", " !~ "},
{ PRINTF, "aprintf", "printf"},
{ PRINT, "print", "print"},
{ SPLIT, "split", "split"},
{ ASSIGN, "assign", " = "},
{ ADDEQ, "assign", " += "},
{ SUBEQ, "assign", " -= "},
{ MULTEQ, "assign", " *= "},
{ DIVEQ, "assign", " /= "},
{ MODEQ, "assign", " %= "},
{ IF, "ifstat", "if("},
{ WHILE, "whilestat", "while("},
{ FOR, "forstat", "for("},
{ IN, "instat", "instat"},
{ NEXT, "jump", "next"},
{ EXIT, "jump", "exit"},
{ BREAK, "jump", "break"},
{ CONTINUE, "jump", "continue"},
{ FNCN, "fncn", "fncn"},
{ GETLINE, "getline", "getline"},
{ 0, ""},
};
#define SIZE LASTTOKEN - FIRSTTOKEN
const char *table[SIZE];
const char *names[SIZE];
extern char *tokname(int);
int
main(void)
{ struct xx *p;
int i;
printf("#include \"awk.def\"\n");
printf("obj nullproc(node **, int);\n");
for(p=proc;p->token!=0;p++)
if(p==proc || strcmp(p->name, (p-1)->name))
printf("extern obj %s(node **, int);\n",p->name);
for(p=proc;p->token!=0;p++)
table[p->token-FIRSTTOKEN]=p->name;
printf("obj (*proctab[%d])(node **, int) = {\n", SIZE);
for(i=0;i<SIZE;i++)
if(table[i]==0) printf("/*%s*/\tnullproc,\n",tokname(i+FIRSTTOKEN));
else printf("/*%s*/\t%s,\n",tokname(i+FIRSTTOKEN),table[i]);
printf("};\n");
printf("char *printname[%d] = {\n", SIZE);
for(p=proc; p->token!=0; p++)
names[p->token-FIRSTTOKEN] = p->pname;
for(i=0; i<SIZE; i++)
printf("/*%s*/\t\"%s\",\n",tokname(i+FIRSTTOKEN),
names[i]?names[i]:"");
printf("};\n");
exit(0);
}
#include "token.c"
syntax highlighted by Code2HTML, v. 0.9.1