#include <stdio.h>
#include <ctype.h>
#include <signal.h>
#include <locale.h>
#include <libintl.h>
#include <stdarg.h>
#include <errno.h>
#include <values.h>
#include <langinfo.h>
#include "awk.h"
#include "y.tab.h"
char *version = "version Aug 27, 2018";
int dbg = 0;
Awkfloat srand_seed = 1;
char *cmdname;
char *lexprog;
int compile_time = 2;
static char **pfile = NULL;
static int npfile = 0;
static int curpfile = 0;
int safe = 0;
int
main(int argc, char *argv[], char *envp[])
{
const char *fs = NULL;
(void) setlocale(LC_ALL, "");
(void) setlocale(LC_NUMERIC, "C");
#if !defined(TEXT_DOMAIN)
#define TEXT_DOMAIN "SYS_TEST"
#endif
(void) textdomain(TEXT_DOMAIN);
cmdname = argv[0];
if (argc == 1) {
(void) fprintf(stderr, gettext(
"Usage: %s [-f programfile | 'program'] [-Ffieldsep] "
"[-v var=value] [files]\n"), cmdname);
exit(1);
}
(void) signal(SIGFPE, fpecatch);
srand_seed = 1;
srand((unsigned int)srand_seed);
yyin = NULL;
symtab = makesymtab(NSYMTAB/NSYMTAB);
while (argc > 1 && argv[1][0] == '-' && argv[1][1] != '\0') {
if (strcmp(argv[1], "-version") == 0 ||
strcmp(argv[1], "--version") == 0) {
(void) printf("awk %s\n", version);
exit(0);
break;
}
if (strcmp(argv[1], "--") == 0) {
argc--;
argv++;
break;
}
switch (argv[1][1]) {
case 's':
if (strcmp(argv[1], "-safe") == 0)
safe = 1;
break;
case 'f':
if (argv[1][2] != 0) {
pfile = realloc(pfile,
sizeof (char *) * (npfile + 1));
if (pfile == NULL)
FATAL("out of space in main");
pfile[npfile++] = &argv[1][2];
} else {
argc--; argv++;
if (argc <= 1)
FATAL("no program filename");
pfile = realloc(pfile,
sizeof (char *) * (npfile + 1));
if (pfile == NULL)
FATAL("out of space in main");
pfile[npfile++] = argv[1];
}
break;
case 'F':
if (argv[1][2] != 0) {
if (argv[1][2] == 't' && argv[1][3] == 0)
fs = "\t";
else if (argv[1][2] != 0)
fs = &argv[1][2];
} else {
argc--; argv++;
if (argc > 1) {
if (argv[1][0] == 't' &&
argv[1][1] == 0)
fs = "\t";
else if (argv[1][0] != 0)
fs = &argv[1][0];
}
}
if (fs == NULL || *fs == '\0')
WARNING("field separator FS is empty");
break;
case 'v':
if (argv[1][2] != 0) {
if (isclvar(&argv[1][2]))
setclvar(&argv[1][2]);
else
FATAL("invalid -v option argument: %s",
&argv[1][2]);
} else {
argc--; argv++;
if (argc <= 1)
FATAL("no variable name");
if (isclvar(argv[1]))
setclvar(argv[1]);
else
FATAL("invalid -v option argument: %s",
argv[1]);
}
break;
case 'd':
dbg = atoi(&argv[1][2]);
if (dbg == 0)
dbg = 1;
(void) printf("awk %s\n", version);
break;
default:
WARNING("unknown option %s ignored", argv[1]);
break;
}
argc--;
argv++;
}
if (npfile == 0) {
if (argc <= 1) {
if (dbg)
exit(0);
FATAL("no program given");
}
dprintf(("program = |%s|\n", argv[1]));
lexprog = argv[1];
argc--;
argv++;
}
recinit(recsize);
syminit();
compile_time = 1;
argv[0] = cmdname;
dprintf(("argc=%d, argv[0]=%s\n", argc, argv[0]));
arginit(argc, argv);
if (!safe)
envinit(envp);
(void) yyparse();
if (fs)
*FS = qstring(fs, '\0');
dprintf(("errorflag=%d\n", errorflag));
(void) setlocale(LC_ALL, "");
if (errorflag == 0) {
compile_time = 0;
run(winner);
} else
bracecheck();
return (errorflag);
}
int
pgetc(void)
{
int c;
for (;;) {
if (yyin == NULL) {
if (curpfile >= npfile)
return (EOF);
yyin = (strcmp(pfile[curpfile], "-") == 0) ?
stdin : fopen(pfile[curpfile], "rF");
if (yyin == NULL) {
FATAL("can't open file %s", pfile[curpfile]);
}
lineno = 1;
}
if ((c = getc(yyin)) != EOF)
return (c);
if (yyin != stdin)
(void) fclose(yyin);
yyin = NULL;
curpfile++;
}
}
char *
cursource(void)
{
if (curpfile < npfile)
return (pfile[curpfile]);
else
return (NULL);
}