#include <stdio.h>
# define U(x) x
# define NLSTATE yyprevious=YYNEWLINE
# define BEGIN yybgin = yysvec + 1 +
# define INITIAL 0
# define YYLERR yysvec
# define YYSTATE (yyestate-yysvec-1)
# define YYOPTIM 1
# define YYLMAX BUFSIZ
#ifndef __cplusplus
# define output(c) (void)putc(c,yyout)
#else
# define lex_output(c) (void)putc(c,yyout)
#endif

#if defined(__cplusplus) || defined(__STDC__)

#if defined(__cplusplus) && defined(__EXTERN_C__)
extern "C" {
#endif
	int yyback(int *, int);
	int yyinput(void);
	int yylook(void);
	void yyoutput(int);
	int yyracc(int);
	int yyreject(void);
	void yyunput(int);
	int yylex(void);
#ifdef YYLEX_E
	void yywoutput(wchar_t);
	wchar_t yywinput(void);
#endif
#ifndef yyless
	int yyless(int);
#endif
#ifndef yywrap
	int yywrap(void);
#endif
#ifdef LEXDEBUG
	void allprint(char);
	void sprint(char *);
#endif
#if defined(__cplusplus) && defined(__EXTERN_C__)
}
#endif

#ifdef __cplusplus
extern "C" {
#endif
	void exit(int);
#ifdef __cplusplus
}
#endif

#endif
# define unput(c) {yytchar= (c);if(yytchar=='\n')yylineno--;*yysptr++=yytchar;}
# define yymore() (yymorfg=1)
#ifndef __cplusplus
# define input() (((yytchar=yysptr>yysbuf?U(*--yysptr):getc(yyin))==10?(yylineno++,yytchar):yytchar)==EOF?0:yytchar)
#else
# define lex_input() (((yytchar=yysptr>yysbuf?U(*--yysptr):getc(yyin))==10?(yylineno++,yytchar):yytchar)==EOF?0:yytchar)
#endif
#define ECHO fprintf(yyout, "%s",yytext)
# define REJECT { nstr = yyreject(); goto yyfussy;}
int yyleng;
char yytext[YYLMAX];
int yymorfg;
extern char *yysptr, yysbuf[];
int yytchar;
FILE *yyin = {stdin}, *yyout = {stdout};
extern int yylineno;
struct yysvf { 
	struct yywork *yystoff;
	struct yysvf *yyother;
	int *yystops;};
struct yysvf *yyestate;
extern struct yysvf yysvec[], *yybgin;
#ifndef lint
static char	rcsid[] = "$Header: /p/src/local/bin/detex/RCS/detex.l,v 2.19 1997/09/10 18:12:37 trinkle Exp $";
#endif


# line 7 "xxx.l"
/*
 * detex [-e environment-list] [-c] [-l] [-n] [-s] [-t] [-w] [file[.tex]]
 *
 *	This program is used to remove TeX or LaTeX constructs from a text
 *	file.
 *
 * Written by:
 *	Daniel Trinkle
 *	Department of Computer Science
 *	Purdue University
 *
 */

#include "detex.h"
#ifdef HAVE_STRING_H
#include <string.h>
#define	index	strchr
#define	rindex	strrchr
#else
#include <strings.h>
#endif
#ifndef MAXPATHLEN
#include <sys/param.h>
#endif
#ifdef OS2
#include <stdlib.h>
#endif

#define	LaBEGIN		if (fLatex) BEGIN
#define	CITEBEGIN	if (fLatex && !fCite) BEGIN
#define	IGNORE		if (fSpace && !fWord) putchar(' ')
#define	SPACE		if (!fWord) putchar(' ')
#define	NEWLINE		if (!fWord) putchar('\n')

char	*SafeMalloc();
#ifndef NO_MALLOC_DECL
char	*malloc();
#endif
#ifdef OS2
void	yyless(int);
#endif

char	*rgsbEnvIgnore[MAXENVS];	/* list of environments ignored */
char	*rgsbIncList[MAXINCLIST];	/* list of includeonly files */
char	*rgsbInputPaths[MAXINPUTPATHS];	/* list of input paths in order */
char	sbCurrentEnv[CCHMAXENV];	/* current environment being ignored */
char	*sbProgName;			/* name we were invoked with */
FILE	*rgfp[NOFILE+1];		/* stack of input/include files */
int	cfp = 0;			/* count of files in stack */
int	cOpenBrace = 0;			/* count of `{' in <SG> */
int	csbEnvIgnore;			/* count of environments ignored */
int	csbIncList = 0;			/* count of includeonly files */
int	csbInputPaths;			/* count of input paths */
int	fLatex = 0;			/* flag to indicated delatex */
int	fWord = 0;			/* flag for -w option */
int	fFollow = 1;			/* flag to follow input/include */
int	fCite = 0;			/* flag to echo \cite and \ref args */
int	fSpace = 0;			/* flag to replace \cs with space */
int	fForcetex = 0;			/* flag to inhibit latex mode */
# define SJ 2
# define SK 4
# define SL 6
# define SM 8
# define SN 10
# define SO 12
# define SP 14
# define SA 16
# define SB 18
# define SC 20
# define SD 22
# define SE 24
# define SF 26
# define SH 28
# define SG 30
# define SI 32
# define YYNEWLINE 10
yylex(){
int nstr; extern int yyprevious;
#ifdef __cplusplus
/* to avoid CC and lint complaining yyfussy not being used ...*/
static int __lex_hack = 0;
if (__lex_hack) goto yyfussy;
#endif
while((nstr = yylook()) >= 0)
yyfussy: switch(nstr){
case 0:
if(yywrap()) return(0); break;
case 1:

# line 75 "xxx.l"
	/* ignore comments */	;
break;
case 2:

# line 77 "xxx.l"
{fLatex = !fForcetex; IGNORE;}
break;
case 3:

# line 79 "xxx.l"
    /* environment start */	{LaBEGIN SA; IGNORE;}
break;
case 4:

# line 81 "xxx.l"
	{   if (BeginEnv("verbatim"))
							BEGIN SD;
						    else
							BEGIN SI;
						    IGNORE;
						}
break;
case 5:

# line 88 "xxx.l"
/* verbatim mode */	{BEGIN SO; IGNORE;}
break;
case 6:

# line 89 "xxx.l"
				ECHO;
break;
case 7:

# line 91 "xxx.l"
				{   if (BeginEnv(yytext))
							BEGIN SD;
						    else
							BEGIN SH;
						    IGNORE;
						}
break;
case 8:

# line 97 "xxx.l"
				NEWLINE;
break;
case 9:

# line 98 "xxx.l"
				;
break;
case 10:

# line 100 "xxx.l"
 /* absorb some environments */	{LaBEGIN SC; IGNORE;}
break;
case 11:

# line 101 "xxx.l"
				NEWLINE;
break;
case 12:

# line 102 "xxx.l"
				;
break;
case 13:

# line 104 "xxx.l"
	 /* end environment */	{   if (EndEnv(yytext))
							BEGIN SO;
						    IGNORE;
						}
break;
case 14:

# line 108 "xxx.l"
				{BEGIN SD; IGNORE;}
break;
case 15:

# line 109 "xxx.l"
				NEWLINE;
break;
case 16:

# line 110 "xxx.l"
				;
break;
case 17:

# line 112 "xxx.l"
    /* ignore args  */	{LaBEGIN SG; IGNORE;}
break;
case 18:

# line 113 "xxx.l"
   /* of these \cs */	{LaBEGIN SH; IGNORE;}
break;
case 19:

# line 114 "xxx.l"
			{LaBEGIN SH; IGNORE;}
break;
case 20:

# line 115 "xxx.l"
			{CITEBEGIN SG; IGNORE;}
break;
case 21:

# line 116 "xxx.l"
		{LaBEGIN SH; IGNORE;}
break;
case 22:

# line 117 "xxx.l"
				{LaBEGIN SH; IGNORE;}
break;
case 23:

# line 118 "xxx.l"
			{SPACE;}
break;
case 24:

# line 119 "xxx.l"
			{LaBEGIN SG; SPACE;}
break;
case 25:

# line 120 "xxx.l"
			{LaBEGIN SH; IGNORE;}
break;
case 26:

# line 121 "xxx.l"
			{CITEBEGIN SH; IGNORE;}
break;
case 27:

# line 122 "xxx.l"
			{LaBEGIN SH; IGNORE;}
break;
case 28:

# line 123 "xxx.l"
				{CITEBEGIN SH; IGNORE;}
break;
case 29:

# line 124 "xxx.l"
			{LaBEGIN SH; IGNORE;}
break;
case 30:

# line 125 "xxx.l"
/* ignore \verb<ch>...<ch> */	{   if (fLatex) {
						 	char verbchar, c;
						 	verbchar = input();
						 	while ((c = input()) != verbchar)
							    if (c == '\n')
								NEWLINE;
						    }
						    IGNORE;
						}
break;
case 31:

# line 134 "xxx.l"
				BEGIN SO;
break;
case 32:

# line 135 "xxx.l"
				NEWLINE;
break;
case 33:

# line 136 "xxx.l"
				;
break;
case 34:

# line 137 "xxx.l"
				{   cOpenBrace++; }
break;
case 35:

# line 138 "xxx.l"
				{   cOpenBrace--;
						    if (cOpenBrace == 0)
							BEGIN SO;
						}
break;
case 36:

# line 142 "xxx.l"
				NEWLINE;
break;
case 37:

# line 143 "xxx.l"
				;
break;
case 38:

# line 145 "xxx.l"
	/* ignore def begin */	{BEGIN SJ; IGNORE;}
break;
case 39:

# line 146 "xxx.l"
				BEGIN SO;
break;
case 40:

# line 147 "xxx.l"
				NEWLINE;
break;
case 41:

# line 148 "xxx.l"
				;
break;
case 42:

# line 150 "xxx.l"
	/* formula mode */	{LaBEGIN SE; IGNORE;}
break;
case 43:

# line 151 "xxx.l"
			BEGIN SO;
break;
case 44:

# line 152 "xxx.l"
				NEWLINE;
break;
case 45:

# line 153 "xxx.l"
				;
break;
case 46:

# line 155 "xxx.l"
	/* display mode */	{LaBEGIN SB; IGNORE;}
break;
case 47:

# line 156 "xxx.l"
			BEGIN SO;
break;
case 48:

# line 157 "xxx.l"
				NEWLINE;
break;
case 49:

# line 158 "xxx.l"
				;
break;
case 50:

# line 160 "xxx.l"
	/* display mode */	{BEGIN SK; IGNORE;}
break;
case 51:

# line 161 "xxx.l"
				BEGIN SO;
break;
case 52:

# line 162 "xxx.l"
				NEWLINE;
break;
case 53:

# line 163 "xxx.l"
				;
break;
case 54:

# line 165 "xxx.l"
	/* math mode */		{BEGIN SN; IGNORE;}
break;
case 55:

# line 166 "xxx.l"
				BEGIN SO;
break;
case 56:

# line 167 "xxx.l"
				NEWLINE;
break;
case 57:

# line 168 "xxx.l"
				;
break;
case 58:

# line 169 "xxx.l"
					;
break;
case 59:

# line 171 "xxx.l"
/* process files */	{LaBEGIN SF; IGNORE;}
break;
case 60:

# line 172 "xxx.l"
			{   IncludeFile(yytext);
						    BEGIN SO;
						}
break;
case 61:

# line 175 "xxx.l"
				NEWLINE;
break;
case 62:

# line 176 "xxx.l"
				;
break;
case 63:

# line 178 "xxx.l"
			{BEGIN SL; IGNORE;}
break;
case 64:

# line 179 "xxx.l"
		AddInclude(yytext);
break;
case 65:

# line 180 "xxx.l"
			{   if (csbIncList == 0)
							rgsbIncList[csbIncList++] = '\0';
						    BEGIN SO;
						}
break;
case 66:

# line 184 "xxx.l"
			NEWLINE;
break;
case 67:

# line 185 "xxx.l"
				;
break;
case 68:

# line 187 "xxx.l"
			{BEGIN SM; IGNORE;}
break;
case 69:

# line 188 "xxx.l"
			{   InputFile(yytext);
						    BEGIN SO;
						}
break;
case 70:

# line 191 "xxx.l"
				NEWLINE;
break;
case 71:

# line 192 "xxx.l"
				;
break;
case 72:

# line 194 "xxx.l"
/* handle ligatures */	{(void)printf("%.2s", yytext+1);}
break;
case 73:

# line 195 "xxx.l"
	{(void)printf("%.1s", yytext+1);}
break;
case 74:

# line 197 "xxx.l"
/* ignore other \cs */	{BEGIN SP; IGNORE;}
break;
case 75:

# line 198 "xxx.l"
				SPACE;
break;
case 76:

# line 199 "xxx.l"
				IGNORE;
break;
case 77:

# line 200 "xxx.l"
			IGNORE;
break;
case 78:

# line 201 "xxx.l"
	IGNORE;
break;
case 79:

# line 202 "xxx.l"
				{BEGIN SO; NEWLINE;}
break;
case 80:

# line 203 "xxx.l"
			{BEGIN SO; IGNORE;}
break;
case 81:

# line 204 "xxx.l"
				{yyless(0);BEGIN SO;}
break;
case 82:

# line 206 "xxx.l"
/* special characters */	IGNORE;
break;
case 83:

# line 207 "xxx.l"
				IGNORE;
break;
case 84:

# line 208 "xxx.l"
				SPACE;
break;
case 85:

# line 210 "xxx.l"
			{   if (fWord)
							(void)printf("%s\n", yytext);
						    else
							ECHO;
						}
break;
case 86:

# line 215 "xxx.l"
				if (!fWord) ECHO;
break;
case 87:

# line 216 "xxx.l"
				if (!fWord) ECHO;
break;
case -1:
break;
default:
(void)fprintf(yyout,"bad switch yylook %d",nstr);
} return(0); }
/* end of yylex */
/******
** main --
**	Set sbProgName to the base of arg 0.
**	Set the input paths.
**	Check for options
**		-c		echo LaTeX \cite, \ref, and \pageref values
**		-e <env-list>	list of LaTeX environments to ignore
**		-l		force latex mode
**		-n		do not follow \input and \include
**		-s		replace control sequences with space
**		-t		force tex mode
**		-w		word only output
**	Set the list of LaTeX environments to ignore.
**	Process each input file.
**	If no input files are specified on the command line, process stdin.
******/

main(cArgs,rgsbArgs)
int	cArgs;
char	*rgsbArgs[];
{
	char	*pch, *sbEnvList = DEFAULTENV, sbBadOpt[2];
	FILE	*TexOpen();
	int	fSawFile = 0, iArgs = 1;

	/* get base name and decide what we are doing, detex or delatex */
#ifdef OS2
	char drive[_MAX_DRIVE], dir[_MAX_DIR];
	char fname[_MAX_FNAME], ext[_MAX_EXT];
#ifdef __EMX__
	_wildcard(&cArgs, &rgsbArgs);
	_response(&cArgs, &rgsbArgs);
#endif
	_splitpath (rgsbArgs[0], drive, dir, fname, ext);
	sbProgName = strlwr(fname);
#else
	if ((sbProgName = rindex(rgsbArgs[0], '/')) != NULL)
	    sbProgName++;
	else
	    sbProgName = rgsbArgs[0];
#endif
	if (strcmp("delatex",sbProgName) == 0)
	    fLatex = 1;

	/* set rgsbInputPaths for use with TexOpen() */
	SetInputPaths();

	/* process command line options */
	while (iArgs < cArgs && *(pch = rgsbArgs[iArgs]) == CHOPT) {
		while (*++pch)
		    switch (*pch) {
		    case CHCITEOPT:
			fCite = 1;
			break;
		    case CHENVOPT:
			sbEnvList = rgsbArgs[++iArgs];
			break;
		    case CHLATEXOPT:
			fLatex = 1;
			break;
		    case CHNOFOLLOWOPT:
			fFollow = 0;
			break;
		    case CHSPACEOPT:
			fSpace = 1;
			break;
		    case CHTEXOPT:
			fForcetex = 1;
			break;
		    case CHWORDOPT:
			fWord = 1;
			break;
		    default:
#ifdef OS2
			OS2UsageExit();
#else
			sbBadOpt[0] = *pch;
			sbBadOpt[1] = '\0';
			Warning("unknown option ignored -", sbBadOpt);
#endif
		    }
		iArgs++;
	}
	SetEnvIgnore(sbEnvList);

	/* process input files */
	for (; iArgs < cArgs; iArgs++) {
	    fSawFile++;
	    if ((yyin = TexOpen(rgsbArgs[iArgs])) == NULL) {
		Warning("can't open file", rgsbArgs[iArgs]);
		continue;;
	    }
	    BEGIN SO;
	    (void)yylex();
	}

	/* if there were no input files, assume stdin */
	if (!fSawFile) {
	    yyin = stdin;
#ifdef OS2
	    if (isatty(fileno(stdin)))
		OS2UsageExit();
#endif
	    BEGIN SO;
	    (void)yylex();
	}
#ifndef FLEX_SCANNER
	if (YYSTATE != SO)
	    ErrorExit("input contains an unterminated mode or environment");
#endif
	return(0);
}

#ifdef FLEX_SCANNER
#undef yywrap
#endif

/******
** yywrap -- handles EOF for lex.  Check to see if the stack of open files
**	has anything on it.  If it does, set yyin to the to value.  If not
**	return the termination signal for lex.
******/

yywrap()
{
	(void)fclose(yyin);
	if (cfp > 0) {
	    yyin = rgfp[--cfp];
	    return(0);
	}
	return(1);
}

#ifdef OS2

/******
** yyless -- return characters to the input stream.  Some systems don't have
**	a yyless routine
******/

void yyless(n)
int n;
{
	int 	i = strlen(yytext);

	while (i > n) unput(yytext[--i]);
	yytext[yyleng = n] = '\0';
}
#endif

/******
** SetEnvIgnore -- sets rgsbEnvIgnore to the values indicated by the
**	sbEnvList.
******/

SetEnvIgnore(sbEnvList)
char	*sbEnvList;
{
	char *sb;

	sb = SafeMalloc(strlen(sbEnvList) + 1, "malloc for SetEnvIgnore failed");
	(void) strcpy(sb, sbEnvList);
	csbEnvIgnore = SeparateList(sb, rgsbEnvIgnore, CHENVSEP, MAXENVS);
	if (csbEnvIgnore == ERROR)
	    ErrorExit("The environtment list contains too many environments");
}

/******
** BeginEnv -- checks to see if sbEnv is in the list rgsbEnvIgnore.  If it
**	is, sbCurrentEnv is set to sbEnv.
******/

BeginEnv(sbEnv)
char	*sbEnv;
{
	int	i;

	if (!fLatex) return(0);
	for (i = 0; i < csbEnvIgnore; i++)
	    if (strcmp(sbEnv, rgsbEnvIgnore[i]) == 0) {
		(void)strcpy(sbCurrentEnv, sbEnv);
		return(1);
	    }
	return(0);
}

/******
** EndEnv -- checks to see if sbEnv is the current environment being ignored.
******/

EndEnv(sbEnv)
char	*sbEnv;
{
	if (!fLatex) return(0);
	if (strcmp(sbEnv, sbCurrentEnv) == 0)
	    return(1);
	return(0);
}

/******
** InputFile -- push the current yyin and open sbFile.  If the open fails,
**	the sbFile is ignored.
******/

InputFile(sbFile)
char	*sbFile;
{
	FILE	*TexOpen();

	if (!fFollow)
	    return;
	rgfp[cfp++] = yyin;
	if ((yyin = TexOpen(sbFile)) == NULL) {
	    Warning("can't open \\input file", sbFile);
	    yyin = rgfp[--cfp];
	}
}

/******
** IncludeFile -- if sbFile is not in the rgsbIncList, push current yyin
**	and open sbFile.  If the open fails, the sbFile is ignored.
******/

IncludeFile(sbFile)
char	*sbFile;
{
	FILE	*TexOpen();

	if (!fFollow)
	    return;
	if (!InList(sbFile))
	    return;
	rgfp[cfp++] = yyin;
	if ((yyin = TexOpen(sbFile)) == NULL) {
	    Warning("can't open \\include file", sbFile);
	    yyin = rgfp[--cfp];
	}
}

/******
** AddInclude -- adds sbFile to the rgsbIncList and increments csbIncList.
**	If the include list is too long, sbFile is ignored.
******/

AddInclude(sbFile)
char	*sbFile;
{
	if (!fFollow)
	    return;
	if (csbIncList >= MAXINCLIST)
	    Warning("\\includeonly list is too long, ignoring", sbFile);
	rgsbIncList[csbIncList] = SafeMalloc(strlen(sbFile) + 1, "malloc for AddInclude failed");
	(void)strcpy(rgsbIncList[csbIncList++], sbFile);
}

/******
** InList -- checks to see if sbFile is in the rgsbIncList.  If there is
**	no list, all files are assumed to be "in the list".
******/

InList(sbFile)
char	*sbFile;
{
	char	*pch, sbBase[MAXPATHLEN];
	int	i;

	if (csbIncList == 0)	/* no list */
	    return(1);
	(void)strcpy(sbBase, sbFile);
	if ((pch = rindex(sbBase, '.')) != NULL)
	    *pch = '\0';
	i = 0;
	while ((i < csbIncList) && rgsbIncList[i])
	    if (strcmp(rgsbIncList[i++], sbBase) == 0)
	        return(1);
	return(0);
}

/******
** SetInputPaths -- sets rgsbInputPaths to the values indicated by the
**	TEXINPUTS environment variable if set or else DEFAULTINPUTS.  If
**	the user's TEXINPUTS has a leading ':' prepend the DEFAULTINPUTS
**	to the path, if there is a trailing ':' append the DEFAULTINPUTS.
**	This is consistent with the most recent TeX.  However, this
**	routine does not honor the '//' construct (expand subdirs).
******/

SetInputPaths()
{
	char *sb, *sbPaths, *getenv();
	int cchDefaults, cchPaths;

	cchDefaults = strlen(DEFAULTINPUTS);
#ifdef OS2
	if ((sb = getenv("TEXINPUT")) == NULL)
#endif
	    if ((sb = getenv("TEXINPUTS")) == NULL)
		sb = DEFAULTINPUTS;
	cchPaths = strlen(sb);
	if (sb[0] == CHPATHSEP)
	    cchPaths += cchDefaults;
	if (sb[strlen(sb) - 1] == CHPATHSEP)
	    cchPaths += cchDefaults;
	sbPaths = SafeMalloc(cchPaths + 1, "malloc for SetInputPaths failed");
	sbPaths[0] = '\0';
	if (sb[0] == CHPATHSEP)
	    (void)strcat(sbPaths, DEFAULTINPUTS);
	(void)strcat(sbPaths, sb);
	if (sb[strlen(sb) - 1] == CHPATHSEP)
	    (void)strcat(sbPaths, DEFAULTINPUTS);

	csbInputPaths = SeparateList(sbPaths, rgsbInputPaths, CHPATHSEP, MAXINPUTPATHS);
	if (csbInputPaths == ERROR)
#ifdef OS2
	    ErrorExit("TEXINPUT(S) environment variable has too many paths");
#else
	    ErrorExit("TEXINPUTS environment variable has too many paths");
#endif
}

/******
** SeparateList -- takes a chSep separated list sbList, replaces the
**	chSep's with NULLs and sets rgsbList[i] to the beginning of
**	the ith word in sbList.  The number of words is returned.  A
**	ERROR is returned if there are more than csbMax words.
******/

SeparateList(sbList, rgsbList, chSep, csbMax)
char	*sbList, *rgsbList[], chSep;
int	csbMax;
{
	int	csbList = 0;

	while (sbList && *sbList && csbList < csbMax) {
	    rgsbList[csbList++] = sbList;
	    if (sbList = index(sbList, chSep))
		*sbList++ = '\0';
	}
	return(sbList && *sbList ? ERROR : csbList);
}

/******
** TexOpen -- tries to open sbFile in each of the rgsbInputPaths in turn.
**	For each input path the following order is used:
**		file.tex - must be as named, if not there go to the next path
**		file.ext - random extension, try it
**		file     - base name, add .tex and try it
**		file     - try it as is
**	Notice that if file exists in the first path and file.tex exists in
**	one of the other paths, file in the first path is what is opened.
**	If the sbFile begins with a '/', no paths are searched.
******/

FILE *
TexOpen(sbFile)
char	*sbFile;
{
	char	*pch, *sbNew;
	FILE	*fp;
	int	iPath;
	static char	sbFullPath[MAXPATHLEN];

	for (iPath = 0; iPath < csbInputPaths; iPath++) {
#ifdef OS2
	    if (*sbFile == '/' || *sbFile == '\\' || strchr(sbFile, ':')) {	/* absolute path */
#else
	    if (*sbFile == '/') {	/* absolute path */
#endif
		(void)sprintf(sbFullPath, "%s", sbFile);
		iPath = csbInputPaths;	/* only check once */
	    } else
		(void)sprintf(sbFullPath, "%s/%s", rgsbInputPaths[iPath], sbFile);
#ifdef OS2
	    pch = sbFullPath;
	    while (pch = strchr(pch, '\\'))
		*pch = '/';
#endif

	    /* If sbFile ends in .tex then it must be there */
	    if ((pch = rindex(sbFullPath, '.')) != NULL
			&& (strcmp(pch, ".tex") == 0))
		if ((fp = fopen(sbFullPath, "r")) != NULL)
		    return(fp);
		else
		    continue;

	    /* if .<ext> then try to open it.  the '.' represents   */
	    /* the beginning of an extension if it is not the first */
	    /* character and it does not follow a '.' or a '/'      */
	    if (pch != NULL && pch > &(sbFullPath[0])
                    && *(pch - 1) != '.' && *(pch - 1) != '/'
		    && (fp = fopen(sbFullPath, "r")) != NULL)
		return(fp);

	    /* just base name, add .tex to the name */
	    sbNew = SafeMalloc(strlen(sbFullPath) + 5, "malloc for TexOpen failed");
	    (void)strcpy(sbNew, sbFullPath);
	    (void)strcat(sbNew, ".tex");
	    if ((fp = fopen(sbNew, "r")) != NULL)
		return(fp);

	    /* try sbFile regardless */
	    if ((fp = fopen(sbFullPath, "r")) != NULL)
		return(fp);
	}
	return((FILE *)NULL);
}

/******
** SafeMalloc -- wrapper around malloc() to check for failure.
******/

char *
SafeMalloc(cch, sbMessage)
int cch;
char *sbMessage;
{
	char *sb;

	if ((sb = (char *)malloc((unsigned)cch)) == NULL)
	    ErrorExit(sbMessage);
	return(sb);
}

/******
** Warning -- print a warning message preceded by the program name.
******/

Warning(sb1, sb2)
char	*sb1, *sb2;
{
	(void)fprintf(stderr, "%s: warning: %s %s\n", sbProgName, sb1, sb2);
}

/******
** ErrorExit -- print an error message preceded by the program name.
**	Stdout is flushed and detex exits.
******/

ErrorExit(sb1)
char	*sb1;
{
	(void)fflush(stdout);
	(void)fprintf(stderr, "%s: error: %s\n", sbProgName, sb1);
	exit(1);
}
#ifdef OS2

/******
** OS2UsageExit -- print OS/2 usage message and exit.
******/

OS2UsageExit()
{
	(void)printf("\n%s [ -clnstw ] [ -e environment-list ] [ filename[.tex] ... ]\n",
		sbProgName);
	puts("  -c  echo LaTeX \\cite, \\ref, and \\pageref values\n  \
-e  <env-list> list of LaTeX environments to ignore\n  \
-l  force latex mode\n  \
-n  do not follow \\input and \\include\n  \
-s  replace control sequences with space\n  \
-t  force tex mode\n  \
-w  word only output");
	exit(0);
}
#endif
int yyvstop[] = {
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

80,
0,

41,
0,

40,
0,

39,
41,
0,

53,
0,

52,
0,

53,
0,

64,
67,
0,

67,
0,

66,
0,

65,
67,
0,

69,
71,
0,

71,
0,

70,
0,

58,
0,

56,
0,

55,
58,
0,

58,
0,

87,
0,

87,
0,

54,
87,
0,

1,
87,
0,

86,
87,
0,

87,
0,

82,
87,
0,

82,
87,
0,

84,
87,
0,

81,
0,

80,
81,
0,

79,
0,

78,
81,
0,

81,
0,

81,
0,

80,
81,
0,

9,
0,

9,
0,

8,
0,

7,
9,
0,

9,
0,

49,
0,

48,
0,

49,
0,

16,
0,

15,
0,

13,
16,
0,

14,
16,
0,

12,
0,

11,
0,

12,
0,

45,
0,

44,
0,

45,
0,

60,
62,
0,

62,
0,

61,
0,

33,
0,

32,
0,

31,
33,
0,

37,
0,

36,
0,

34,
37,
0,

35,
37,
0,

6,
0,

6,
0,

51,
0,

64,
0,

69,
0,

57,
0,

83,
0,

50,
0,

1,
0,

86,
0,

85,
0,

76,
0,

75,
76,
0,

42,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

46,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

74,
76,
0,

80,
0,

80,
0,

78,
0,

77,
0,

7,
0,

47,
0,

13,
0,

43,
0,

60,
0,

85,
0,

74,
0,

74,
0,

73,
0,

73,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

72,
0,

72,
0,

74,
0,

74,
0,

74,
0,

38,
74,
0,

74,
0,

22,
74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

28,
74,
0,

74,
0,

74,
0,

10,
0,

74,
0,

74,
0,

74,
0,

74,
0,

20,
74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

30,
74,
0,

3,
74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

24,
74,
0,

68,
74,
0,

25,
74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

17,
74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

59,
74,
0,

26,
74,
0,

74,
0,

74,
0,

74,
0,

19,
74,
0,

74,
0,

23,
74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

74,
0,

27,
74,
0,

74,
0,

4,
0,

74,
0,

74,
0,

74,
0,

29,
74,
0,

74,
0,

74,
0,

63,
74,
0,

18,
74,
0,

74,
0,

21,
74,
0,

5,
0,

2,
0,
0};
# define YYTYPE int
struct yywork { YYTYPE verify, advance; } yycrank[] = {
0,0,	0,0,	3,35,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	5,38,	3,35,	3,36,	
104,0,	0,0,	0,0,	0,0,	
7,41,	5,38,	5,39,	0,0,	
0,0,	0,0,	34,0,	0,0,	
7,42,	7,43,	0,0,	0,0,	
113,147,	113,148,	0,0,	0,0,	
62,129,	0,0,	3,35,	0,0,	
0,0,	6,40,	40,98,	51,101,	
3,35,	5,38,	12,50,	54,103,	
5,40,	3,35,	3,35,	5,38,	
7,41,	3,35,	85,141,	113,147,	
5,38,	5,38,	7,41,	62,129,	
5,38,	14,54,	14,55,	7,42,	
7,41,	0,0,	0,0,	7,41,	
0,0,	3,35,	3,35,	72,135,	
72,135,	122,147,	122,148,	0,0,	
5,38,	5,38,	69,134,	69,134,	
0,0,	3,35,	9,45,	7,41,	
7,41,	112,146,	99,0,	99,0,	
5,38,	112,146,	9,46,	9,47,	
114,147,	114,148,	72,135,	7,41,	
122,147,	3,35,	0,0,	75,138,	
0,0,	69,134,	53,102,	125,158,	
5,38,	150,168,	116,146,	82,140,	
97,143,	99,0,	116,146,	7,41,	
117,149,	118,151,	9,45,	114,147,	
117,150,	119,152,	120,154,	121,155,	
9,45,	99,0,	126,159,	11,48,	
128,161,	9,45,	9,45,	119,153,	
3,37,	9,45,	3,35,	11,48,	
11,49,	16,61,	12,48,	5,38,	
20,73,	5,38,	24,80,	26,83,	
34,96,	67,130,	7,42,	137,162,	
7,44,	9,45,	9,45,	140,163,	
113,148,	14,59,	62,130,	14,60,	
114,146,	143,164,	149,167,	11,48,	
151,169,	9,45,	11,50,	124,147,	
124,148,	11,48,	127,160,	152,170,	
153,171,	154,172,	11,48,	11,48,	
100,0,	100,0,	11,48,	155,173,	
157,177,	9,45,	122,156,	13,52,	
127,146,	158,178,	131,0,	131,0,	
72,137,	159,179,	124,147,	13,52,	
13,52,	15,61,	11,48,	11,48,	
160,180,	122,148,	161,181,	100,0,	
69,135,	15,62,	15,63,	162,182,	
156,174,	156,175,	11,48,	163,183,	
99,0,	131,0,	99,0,	164,184,	
9,46,	167,185,	9,46,	13,53,	
114,148,	156,176,	13,54,	13,55,	
169,189,	13,52,	11,51,	171,190,	
173,191,	15,61,	13,52,	13,52,	
174,192,	175,193,	13,56,	15,64,	
176,194,	177,195,	17,68,	178,196,	
15,61,	15,64,	123,147,	123,148,	
15,65,	168,186,	17,69,	17,70,	
168,187,	180,197,	13,52,	13,57,	
142,0,	142,0,	181,198,	168,188,	
182,199,	11,48,	11,48,	11,48,	
15,65,	15,65,	13,57,	124,146,	
185,201,	123,147,	146,165,	146,166,	
186,202,	187,203,	17,68,	188,204,	
15,65,	190,205,	191,206,	142,0,	
17,68,	192,207,	13,58,	193,208,	
194,209,	17,68,	17,68,	195,210,	
19,73,	17,68,	197,213,	124,148,	
15,66,	146,165,	196,211,	196,212,	
19,73,	19,74,	100,0,	199,214,	
100,0,	202,218,	203,219,	204,220,	
205,221,	17,68,	17,71,	206,222,	
131,0,	207,223,	21,76,	211,224,	
212,225,	13,59,	13,59,	13,59,	
13,60,	17,71,	21,76,	21,77,	
19,73,	147,147,	147,148,	15,67,	
15,61,	15,61,	19,73,	213,226,	
214,227,	215,228,	218,230,	19,73,	
19,73,	17,68,	123,157,	19,73,	
219,231,	220,232,	184,184,	184,184,	
221,233,	222,234,	21,76,	223,235,	
147,147,	224,236,	225,237,	226,238,	
21,76,	227,239,	23,80,	19,73,	
19,73,	21,76,	21,76,	200,200,	
200,200,	21,76,	23,80,	23,81,	
25,83,	184,184,	123,148,	19,73,	
17,72,	228,240,	17,68,	229,241,	
25,83,	25,84,	142,0,	231,242,	
142,0,	21,76,	21,78,	232,243,	
165,165,	165,166,	200,200,	19,75,	
233,244,	234,245,	23,80,	235,246,	
237,247,	21,78,	146,166,	238,248,	
23,80,	239,249,	240,250,	241,251,	
25,83,	23,80,	23,80,	242,252,	
244,253,	23,80,	25,83,	165,165,	
246,254,	21,76,	247,255,	25,83,	
25,83,	201,216,	201,216,	25,83,	
248,256,	250,258,	19,73,	19,73,	
19,73,	23,80,	23,80,	251,259,	
252,260,	217,217,	217,217,	253,261,	
254,262,	256,263,	27,86,	25,83,	
25,83,	23,80,	216,216,	216,216,	
201,216,	258,264,	27,87,	27,88,	
21,76,	259,265,	21,79,	25,83,	
260,266,	147,148,	261,267,	262,268,	
217,217,	23,82,	264,269,	265,270,	
249,249,	249,249,	266,271,	267,272,	
269,273,	216,216,	270,274,	25,85,	
184,200,	272,275,	27,86,	274,277,	
273,273,	273,273,	277,277,	277,277,	
27,86,	0,0,	29,89,	0,0,	
200,215,	27,86,	27,86,	249,249,	
0,0,	27,86,	29,89,	29,90,	
23,80,	23,80,	23,80,	0,0,	
0,0,	0,0,	0,0,	273,273,	
0,0,	277,277,	25,83,	25,83,	
25,83,	27,86,	27,86,	0,0,	
0,0,	0,0,	0,0,	0,0,	
165,166,	0,0,	29,89,	0,0,	
0,0,	27,86,	0,0,	0,0,	
29,89,	0,0,	0,0,	0,0,	
0,0,	29,89,	29,89,	31,92,	
217,229,	29,89,	0,0,	0,0,	
0,0,	27,86,	0,0,	31,92,	
31,93,	0,0,	0,0,	201,217,	
0,0,	0,0,	0,0,	0,0,	
0,0,	29,89,	29,89,	56,105,	
56,105,	56,105,	56,105,	56,105,	
56,105,	56,105,	56,105,	56,105,	
56,105,	29,89,	0,0,	31,92,	
216,217,	0,0,	0,0,	0,0,	
27,87,	31,92,	27,87,	33,96,	
0,0,	0,0,	31,92,	31,92,	
0,0,	29,89,	31,92,	33,96,	
33,0,	41,99,	0,0,	0,0,	
249,257,	0,0,	0,0,	0,0,	
0,0,	41,0,	41,0,	0,0,	
0,0,	0,0,	31,92,	31,92,	
273,276,	0,0,	277,278,	0,0,	
0,0,	0,0,	0,0,	33,96,	
0,0,	0,0,	31,92,	0,0,	
29,89,	33,96,	29,91,	0,0,	
41,0,	41,99,	33,96,	33,96,	
0,0,	0,0,	33,96,	41,99,	
0,0,	0,0,	31,92,	0,0,	
41,0,	41,99,	0,0,	0,0,	
41,99,	0,0,	0,0,	0,0,	
0,0,	45,100,	33,96,	33,96,	
0,0,	0,0,	0,0,	0,0,	
0,0,	45,0,	45,0,	55,104,	
41,99,	41,99,	33,96,	0,0,	
0,0,	0,0,	0,0,	55,104,	
55,0,	31,94,	0,0,	31,95,	
41,99,	0,0,	0,0,	0,0,	
0,0,	0,0,	33,97,	0,0,	
45,0,	45,100,	0,0,	0,0,	
0,0,	0,0,	0,0,	45,100,	
41,99,	0,0,	0,0,	55,104,	
45,100,	45,100,	0,0,	0,0,	
45,100,	55,104,	0,0,	0,0,	
0,0,	0,0,	55,104,	55,104,	
0,0,	0,0,	55,104,	0,0,	
0,0,	33,96,	33,96,	33,96,	
45,100,	45,100,	0,0,	0,0,	
0,0,	0,0,	0,0,	41,0,	
0,0,	41,0,	55,104,	55,104,	
45,100,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	55,104,	0,0,	
0,0,	0,0,	0,0,	0,0,	
45,100,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	55,104,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	57,106,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	45,0,	
0,0,	45,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	55,104,	0,0,	55,104,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	57,107,	57,107,	
57,107,	57,107,	58,108,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	58,108,	58,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	58,109,	58,108,	0,0,	
0,0,	0,0,	0,0,	0,0,	
58,108,	58,110,	0,0,	0,0,	
0,0,	58,108,	58,108,	0,0,	
0,0,	58,108,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	58,111,	58,112,	58,111,	
58,111,	58,111,	58,111,	58,111,	
58,111,	58,111,	58,111,	58,111,	
58,111,	58,113,	58,111,	58,111,	
58,114,	58,111,	58,111,	58,111,	
58,111,	58,111,	58,111,	58,111,	
58,111,	58,111,	58,111,	58,111,	
58,115,	58,108,	0,0,	0,0,	
0,0,	0,0,	58,116,	58,117,	
58,118,	58,119,	58,120,	58,121,	
58,111,	58,111,	58,122,	0,0,	
58,111,	58,123,	58,111,	58,111,	
58,124,	58,125,	58,111,	58,126,	
58,127,	58,111,	58,111,	58,128,	
58,111,	58,111,	58,111,	58,111,	
58,108,	64,131,	58,108,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	64,0,	64,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
64,0,	64,131,	0,0,	0,0,	
0,0,	0,0,	0,0,	64,131,	
0,0,	0,0,	0,0,	0,0,	
64,131,	64,131,	0,0,	0,0,	
64,131,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
64,131,	64,131,	0,0,	0,0,	
0,0,	65,131,	0,0,	0,0,	
0,0,	0,0,	0,0,	65,131,	
64,131,	0,0,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
0,0,	0,0,	0,0,	65,131,	
64,131,	0,0,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	0,0,	0,0,	64,0,	
0,0,	64,131,	65,131,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	65,132,	65,132,	65,132,	
65,132,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
66,133,	66,133,	66,133,	66,133,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	71,136,	71,136,	
71,136,	71,136,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
78,139,	78,139,	78,139,	78,139,	
86,142,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
86,0,	86,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	86,0,	
86,142,	0,0,	0,0,	0,0,	
0,0,	0,0,	86,142,	0,0,	
0,0,	0,0,	0,0,	86,142,	
86,142,	0,0,	0,0,	86,142,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	86,142,	
86,142,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	86,142,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	86,142,	
0,0,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	0,0,	
0,0,	0,0,	86,0,	0,0,	
86,0,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	106,144,	
106,144,	106,144,	106,144,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	111,145,	111,145,	
111,145,	111,145,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
144,144,	144,144,	144,144,	144,144,	
0,0};
struct yysvf yysvec[] = {
0,	0,	0,
yycrank+0,	0,		yyvstop+1,
yycrank+0,	0,		yyvstop+3,
yycrank+-1,	0,		yyvstop+5,
yycrank+0,	yysvec+3,	yyvstop+7,
yycrank+-8,	0,		yyvstop+9,
yycrank+-1,	yysvec+5,	yyvstop+11,
yycrank+-15,	0,		yyvstop+13,
yycrank+0,	yysvec+7,	yyvstop+15,
yycrank+-77,	0,		yyvstop+17,
yycrank+0,	yysvec+9,	yyvstop+19,
yycrank+-118,	0,		yyvstop+21,
yycrank+-6,	yysvec+11,	yyvstop+23,
yycrank+-170,	0,		yyvstop+25,
yycrank+-21,	yysvec+13,	yyvstop+27,
yycrank+-180,	0,		yyvstop+29,
yycrank+-5,	yysvec+15,	yyvstop+31,
yycrank+-221,	0,		yyvstop+33,
yycrank+0,	yysvec+17,	yyvstop+35,
yycrank+-267,	0,		yyvstop+37,
yycrank+-8,	yysvec+19,	yyvstop+39,
yycrank+-289,	0,		yyvstop+41,
yycrank+0,	yysvec+21,	yyvstop+43,
yycrank+-329,	0,		yyvstop+45,
yycrank+-10,	yysvec+23,	yyvstop+47,
yycrank+-339,	0,		yyvstop+49,
yycrank+-11,	yysvec+25,	yyvstop+51,
yycrank+-401,	0,		yyvstop+53,
yycrank+0,	yysvec+27,	yyvstop+55,
yycrank+-441,	0,		yyvstop+57,
yycrank+0,	yysvec+29,	yyvstop+59,
yycrank+-486,	0,		yyvstop+61,
yycrank+0,	yysvec+31,	yyvstop+63,
yycrank+-526,	0,		yyvstop+65,
yycrank+-12,	yysvec+33,	yyvstop+67,
yycrank+0,	0,		yyvstop+69,
yycrank+0,	0,		yyvstop+71,
yycrank+0,	0,		yyvstop+73,
yycrank+0,	0,		yyvstop+76,
yycrank+0,	0,		yyvstop+78,
yycrank+2,	0,		yyvstop+80,
yycrank+-536,	0,		yyvstop+82,
yycrank+0,	0,		yyvstop+85,
yycrank+0,	0,		yyvstop+87,
yycrank+0,	0,		yyvstop+89,
yycrank+-588,	0,		yyvstop+92,
yycrank+0,	0,		yyvstop+95,
yycrank+0,	0,		yyvstop+97,
yycrank+0,	0,		yyvstop+99,
yycrank+0,	0,		yyvstop+101,
yycrank+0,	0,		yyvstop+103,
yycrank+3,	0,		yyvstop+106,
yycrank+0,	0,		yyvstop+108,
yycrank+2,	0,		yyvstop+110,
yycrank+7,	0,		yyvstop+112,
yycrank+-598,	0,		yyvstop+115,
yycrank+459,	0,		yyvstop+118,
yycrank+659,	0,		yyvstop+121,
yycrank+-781,	0,		yyvstop+123,
yycrank+0,	0,		yyvstop+126,
yycrank+0,	0,		yyvstop+129,
yycrank+0,	0,		yyvstop+132,
yycrank+23,	0,		yyvstop+134,
yycrank+0,	0,		yyvstop+137,
yycrank+-904,	0,		yyvstop+139,
yycrank+934,	0,		yyvstop+142,
yycrank+993,	0,		yyvstop+144,
yycrank+14,	0,		yyvstop+146,
yycrank+0,	0,		yyvstop+149,
yycrank+65,	0,		yyvstop+151,
yycrank+0,	yysvec+69,	yyvstop+153,
yycrank+1051,	0,		yyvstop+155,
yycrank+58,	0,		yyvstop+158,
yycrank+0,	0,		yyvstop+160,
yycrank+0,	0,		yyvstop+162,
yycrank+2,	0,		yyvstop+164,
yycrank+0,	0,		yyvstop+166,
yycrank+0,	0,		yyvstop+168,
yycrank+1109,	0,		yyvstop+170,
yycrank+0,	0,		yyvstop+173,
yycrank+0,	0,		yyvstop+176,
yycrank+0,	0,		yyvstop+178,
yycrank+2,	0,		yyvstop+180,
yycrank+0,	0,		yyvstop+182,
yycrank+0,	0,		yyvstop+184,
yycrank+9,	0,		yyvstop+186,
yycrank+-1231,	0,		yyvstop+188,
yycrank+0,	0,		yyvstop+191,
yycrank+0,	0,		yyvstop+193,
yycrank+0,	0,		yyvstop+195,
yycrank+0,	0,		yyvstop+197,
yycrank+0,	0,		yyvstop+199,
yycrank+0,	0,		yyvstop+202,
yycrank+0,	0,		yyvstop+204,
yycrank+0,	0,		yyvstop+206,
yycrank+0,	0,		yyvstop+209,
yycrank+0,	0,		yyvstop+212,
yycrank+3,	0,		yyvstop+214,
yycrank+0,	0,		yyvstop+216,
yycrank+-73,	yysvec+41,	yyvstop+218,
yycrank+-155,	yysvec+45,	yyvstop+220,
yycrank+0,	0,		yyvstop+222,
yycrank+0,	0,		yyvstop+224,
yycrank+0,	0,		yyvstop+226,
yycrank+-2,	yysvec+55,	yyvstop+228,
yycrank+0,	yysvec+56,	yyvstop+230,
yycrank+1260,	yysvec+57,	0,	
yycrank+0,	yysvec+57,	yyvstop+232,
yycrank+0,	0,		yyvstop+234,
yycrank+0,	0,		yyvstop+236,
yycrank+0,	0,		yyvstop+239,
yycrank+1319,	0,		yyvstop+242,
yycrank+16,	yysvec+111,	yyvstop+245,
yycrank+19,	yysvec+111,	yyvstop+248,
yycrank+79,	yysvec+111,	yyvstop+251,
yycrank+0,	0,		yyvstop+254,
yycrank+5,	yysvec+111,	yyvstop+257,
yycrank+7,	yysvec+111,	yyvstop+260,
yycrank+4,	yysvec+111,	yyvstop+263,
yycrank+12,	yysvec+111,	yyvstop+266,
yycrank+4,	yysvec+111,	yyvstop+269,
yycrank+4,	yysvec+111,	yyvstop+272,
yycrank+60,	yysvec+111,	yyvstop+275,
yycrank+217,	yysvec+111,	yyvstop+278,
yycrank+146,	yysvec+111,	yyvstop+281,
yycrank+2,	yysvec+111,	yyvstop+284,
yycrank+17,	yysvec+111,	yyvstop+287,
yycrank+57,	yysvec+111,	yyvstop+290,
yycrank+19,	yysvec+111,	yyvstop+293,
yycrank+0,	yysvec+62,	yyvstop+296,
yycrank+0,	yysvec+67,	yyvstop+298,
yycrank+-165,	yysvec+64,	yyvstop+300,
yycrank+0,	yysvec+65,	0,	
yycrank+0,	yysvec+66,	yyvstop+302,
yycrank+0,	yysvec+69,	0,	
yycrank+0,	yysvec+72,	0,	
yycrank+0,	yysvec+71,	yyvstop+304,
yycrank+38,	0,		0,	
yycrank+0,	0,		yyvstop+306,
yycrank+0,	yysvec+78,	yyvstop+308,
yycrank+33,	0,		0,	
yycrank+0,	0,		yyvstop+310,
yycrank+-227,	yysvec+86,	yyvstop+312,
yycrank+39,	0,		0,	
yycrank+1377,	0,		yyvstop+314,
yycrank+0,	yysvec+111,	yyvstop+316,
yycrank+241,	yysvec+111,	yyvstop+318,
yycrank+292,	0,		yyvstop+320,
yycrank+0,	0,		yyvstop+322,
yycrank+47,	yysvec+111,	yyvstop+324,
yycrank+3,	yysvec+111,	yyvstop+326,
yycrank+36,	yysvec+111,	yyvstop+328,
yycrank+57,	yysvec+111,	yyvstop+330,
yycrank+61,	yysvec+111,	yyvstop+332,
yycrank+61,	yysvec+111,	yyvstop+334,
yycrank+56,	yysvec+111,	yyvstop+336,
yycrank+93,	yysvec+111,	yyvstop+338,
yycrank+70,	yysvec+111,	yyvstop+340,
yycrank+70,	yysvec+111,	yyvstop+342,
yycrank+75,	yysvec+111,	yyvstop+344,
yycrank+68,	yysvec+111,	yyvstop+346,
yycrank+72,	yysvec+111,	yyvstop+348,
yycrank+77,	0,		0,	
yycrank+95,	0,		0,	
yycrank+99,	0,		0,	
yycrank+347,	0,		yyvstop+350,
yycrank+0,	0,		yyvstop+352,
yycrank+96,	yysvec+111,	yyvstop+354,
yycrank+124,	yysvec+111,	yyvstop+356,
yycrank+107,	yysvec+111,	yyvstop+358,
yycrank+0,	yysvec+111,	yyvstop+360,
yycrank+94,	yysvec+111,	yyvstop+363,
yycrank+0,	yysvec+111,	yyvstop+365,
yycrank+96,	yysvec+111,	yyvstop+368,
yycrank+108,	yysvec+111,	yyvstop+370,
yycrank+116,	yysvec+111,	yyvstop+372,
yycrank+103,	yysvec+111,	yyvstop+374,
yycrank+120,	yysvec+111,	yyvstop+376,
yycrank+122,	yysvec+111,	yyvstop+378,
yycrank+0,	yysvec+111,	yyvstop+380,
yycrank+134,	yysvec+111,	yyvstop+383,
yycrank+140,	yysvec+111,	yyvstop+385,
yycrank+142,	0,		0,	
yycrank+0,	0,		yyvstop+387,
yycrank+309,	0,		0,	
yycrank+138,	yysvec+111,	yyvstop+389,
yycrank+136,	yysvec+111,	yyvstop+391,
yycrank+148,	yysvec+111,	yyvstop+393,
yycrank+139,	yysvec+111,	yyvstop+395,
yycrank+0,	yysvec+111,	yyvstop+397,
yycrank+148,	yysvec+111,	yyvstop+400,
yycrank+148,	yysvec+111,	yyvstop+402,
yycrank+144,	yysvec+111,	yyvstop+404,
yycrank+143,	yysvec+111,	yyvstop+406,
yycrank+148,	yysvec+111,	yyvstop+408,
yycrank+159,	yysvec+111,	yyvstop+410,
yycrank+160,	yysvec+111,	yyvstop+412,
yycrank+159,	yysvec+111,	yyvstop+414,
yycrank+0,	yysvec+111,	yyvstop+416,
yycrank+182,	0,		0,	
yycrank+326,	0,		0,	
yycrank+376,	yysvec+111,	yyvstop+419,
yycrank+180,	yysvec+111,	yyvstop+422,
yycrank+171,	yysvec+111,	yyvstop+424,
yycrank+162,	yysvec+111,	yyvstop+426,
yycrank+183,	yysvec+111,	yyvstop+428,
yycrank+176,	yysvec+111,	yyvstop+430,
yycrank+189,	yysvec+111,	yyvstop+432,
yycrank+0,	yysvec+111,	yyvstop+434,
yycrank+0,	yysvec+111,	yyvstop+437,
yycrank+0,	yysvec+111,	yyvstop+440,
yycrank+190,	yysvec+111,	yyvstop+443,
yycrank+176,	yysvec+111,	yyvstop+445,
yycrank+190,	yysvec+111,	yyvstop+447,
yycrank+192,	0,		0,	
yycrank+208,	0,		0,	
yycrank+397,	0,		0,	
yycrank+388,	0,		0,	
yycrank+201,	yysvec+111,	yyvstop+449,
yycrank+213,	yysvec+111,	yyvstop+451,
yycrank+209,	yysvec+111,	yyvstop+453,
yycrank+210,	yysvec+111,	yyvstop+455,
yycrank+205,	yysvec+111,	yyvstop+457,
yycrank+222,	yysvec+111,	yyvstop+459,
yycrank+223,	yysvec+111,	yyvstop+461,
yycrank+205,	yysvec+111,	yyvstop+463,
yycrank+217,	yysvec+111,	yyvstop+465,
yycrank+224,	0,		0,	
yycrank+231,	0,		0,	
yycrank+236,	0,		0,	
yycrank+0,	yysvec+111,	yyvstop+467,
yycrank+237,	yysvec+111,	yyvstop+470,
yycrank+254,	yysvec+111,	yyvstop+472,
yycrank+244,	yysvec+111,	yyvstop+474,
yycrank+260,	yysvec+111,	yyvstop+476,
yycrank+252,	yysvec+111,	yyvstop+478,
yycrank+0,	yysvec+111,	yyvstop+481,
yycrank+256,	yysvec+111,	yyvstop+484,
yycrank+251,	yysvec+111,	yyvstop+486,
yycrank+260,	0,		0,	
yycrank+272,	0,		0,	
yycrank+272,	0,		0,	
yycrank+278,	yysvec+111,	yyvstop+488,
yycrank+0,	yysvec+111,	yyvstop+490,
yycrank+261,	yysvec+111,	yyvstop+493,
yycrank+0,	yysvec+111,	yyvstop+495,
yycrank+270,	yysvec+111,	yyvstop+498,
yycrank+281,	yysvec+111,	yyvstop+500,
yycrank+287,	yysvec+111,	yyvstop+502,
yycrank+415,	0,		0,	
yycrank+292,	0,		0,	
yycrank+278,	0,		0,	
yycrank+284,	yysvec+111,	yyvstop+504,
yycrank+283,	yysvec+111,	yyvstop+506,
yycrank+292,	yysvec+111,	yyvstop+508,
yycrank+0,	yysvec+111,	yyvstop+510,
yycrank+287,	yysvec+111,	yyvstop+513,
yycrank+0,	0,		yyvstop+515,
yycrank+293,	0,		0,	
yycrank+304,	0,		0,	
yycrank+312,	yysvec+111,	yyvstop+517,
yycrank+297,	yysvec+111,	yyvstop+519,
yycrank+298,	yysvec+111,	yyvstop+521,
yycrank+0,	yysvec+111,	yyvstop+523,
yycrank+317,	0,		0,	
yycrank+322,	0,		0,	
yycrank+305,	yysvec+111,	yyvstop+526,
yycrank+319,	yysvec+111,	yyvstop+528,
yycrank+0,	yysvec+111,	yyvstop+530,
yycrank+319,	0,		0,	
yycrank+320,	0,		0,	
yycrank+0,	yysvec+111,	yyvstop+533,
yycrank+332,	yysvec+111,	yyvstop+536,
yycrank+427,	0,		0,	
yycrank+319,	0,		0,	
yycrank+0,	yysvec+111,	yyvstop+538,
yycrank+0,	0,		yyvstop+541,
yycrank+429,	0,		0,	
yycrank+0,	0,		yyvstop+543,
0,	0,	0};
struct yywork *yytop = yycrank+1499;
struct yysvf *yybgin = yysvec+1;
char yymatch[] = {
  0,   1,   1,   1,   1,   1,   1,   1, 
  1,   9,  10,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  9,  33,   1,   1,   1,   1,   1,  39, 
  1,   1,   1,   1,  44,  45,   1,   1, 
 48,  48,  48,  48,  48,  48,  48,  48, 
 48,  48,   1,   1,   1,  45,   1,  33, 
 64,  65,  65,  65,  65,  65,  65,  65, 
 65,  65,  65,  65,  76,  65,  65,  76, 
 65,  65,  65,  65,  65,  65,  65,  65, 
 65,  65,  65,   1,  92,   1,   1,   1, 
 45,  65,  65,  65,  65,  65,  65,  65, 
 65,  76,  76,  65,  76,  65,  65,  76, 
 65,  65,  65,  65,  65,  65,  65,  65, 
 65,  65,  65, 123,  92, 125,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
  1,   1,   1,   1,   1,   1,   1,   1, 
0};
char yyextra[] = {
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0};
/*	Copyright (c) 1989 AT&T	*/
/*	  All Rights Reserved  	*/

/*	THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T	*/
/*	The copyright notice above does not evidence any   	*/
/*	actual or intended publication of such source code.	*/

#pragma ident	"@(#)ncform	6.8	95/02/11 SMI"

int yylineno =1;
# define YYU(x) x
# define NLSTATE yyprevious=YYNEWLINE
struct yysvf *yylstate [YYLMAX], **yylsp, **yyolsp;
char yysbuf[YYLMAX];
char *yysptr = yysbuf;
int *yyfnd;
extern struct yysvf *yyestate;
int yyprevious = YYNEWLINE;
#if defined(__cplusplus) || defined(__STDC__)
int yylook(void)
#else
yylook()
#endif
{
	register struct yysvf *yystate, **lsp;
	register struct yywork *yyt;
	struct yysvf *yyz;
	int yych, yyfirst;
	struct yywork *yyr;
# ifdef LEXDEBUG
	int debug;
# endif
	char *yylastch;
	/* start off machines */
# ifdef LEXDEBUG
	debug = 0;
# endif
	yyfirst=1;
	if (!yymorfg)
		yylastch = yytext;
	else {
		yymorfg=0;
		yylastch = yytext+yyleng;
		}
	for(;;){
		lsp = yylstate;
		yyestate = yystate = yybgin;
		if (yyprevious==YYNEWLINE) yystate++;
		for (;;){
# ifdef LEXDEBUG
			if(debug)fprintf(yyout,"state %d\n",yystate-yysvec-1);
# endif
			yyt = yystate->yystoff;
			if(yyt == yycrank && !yyfirst){  /* may not be any transitions */
				yyz = yystate->yyother;
				if(yyz == 0)break;
				if(yyz->yystoff == yycrank)break;
				}
#ifndef __cplusplus
			*yylastch++ = yych = input();
#else
			*yylastch++ = yych = lex_input();
#endif
			if(yylastch > &yytext[YYLMAX]) {
				fprintf(yyout,"Input string too long, limit %d\n",YYLMAX);
				exit(1);
			}
			yyfirst=0;
		tryagain:
# ifdef LEXDEBUG
			if(debug){
				fprintf(yyout,"char ");
				allprint(yych);
				putchar('\n');
				}
# endif
			yyr = yyt;
			if ( (int)yyt > (int)yycrank){
				yyt = yyr + yych;
				if (yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transitions */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					if(lsp > &yylstate[YYLMAX]) {
						fprintf(yyout,"Input string too long, limit %d\n",YYLMAX);
						exit(1);
					}
					goto contin;
					}
				}
# ifdef YYOPTIM
			else if((int)yyt < (int)yycrank) {		/* r < yycrank */
				yyt = yyr = yycrank+(yycrank-yyt);
# ifdef LEXDEBUG
				if(debug)fprintf(yyout,"compressed state\n");
# endif
				yyt = yyt + yych;
				if(yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transitions */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					if(lsp > &yylstate[YYLMAX]) {
						fprintf(yyout,"Input string too long, limit %d\n",YYLMAX);
						exit(1);
					}
					goto contin;
					}
				yyt = yyr + YYU(yymatch[yych]);
# ifdef LEXDEBUG
				if(debug){
					fprintf(yyout,"try fall back character ");
					allprint(YYU(yymatch[yych]));
					putchar('\n');
					}
# endif
				if(yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transition */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					if(lsp > &yylstate[YYLMAX]) {
						fprintf(yyout,"Input string too long, limit %d\n",YYLMAX);
						exit(1);
					}
					goto contin;
					}
				}
			if ((yystate = yystate->yyother) && (yyt= yystate->yystoff) != yycrank){
# ifdef LEXDEBUG
				if(debug)fprintf(yyout,"fall back to state %d\n",yystate-yysvec-1);
# endif
				goto tryagain;
				}
# endif
			else
				{unput(*--yylastch);break;}
		contin:
# ifdef LEXDEBUG
			if(debug){
				fprintf(yyout,"state %d char ",yystate-yysvec-1);
				allprint(yych);
				putchar('\n');
				}
# endif
			;
			}
# ifdef LEXDEBUG
		if(debug){
			fprintf(yyout,"stopped at %d with ",*(lsp-1)-yysvec-1);
			allprint(yych);
			putchar('\n');
			}
# endif
		while (lsp-- > yylstate){
			*yylastch-- = 0;
			if (*lsp != 0 && (yyfnd= (*lsp)->yystops) && *yyfnd > 0){
				yyolsp = lsp;
				if(yyextra[*yyfnd]){		/* must backup */
					while(yyback((*lsp)->yystops,-*yyfnd) != 1 && lsp > yylstate){
						lsp--;
						unput(*yylastch--);
						}
					}
				yyprevious = YYU(*yylastch);
				yylsp = lsp;
				yyleng = yylastch-yytext+1;
				yytext[yyleng] = 0;
# ifdef LEXDEBUG
				if(debug){
					fprintf(yyout,"\nmatch ");
					sprint(yytext);
					fprintf(yyout," action %d\n",*yyfnd);
					}
# endif
				return(*yyfnd++);
				}
			unput(*yylastch);
			}
		if (yytext[0] == 0  /* && feof(yyin) */)
			{
			yysptr=yysbuf;
			return(0);
			}
#ifndef __cplusplus
		yyprevious = yytext[0] = input();
		if (yyprevious>0)
			output(yyprevious);
#else
		yyprevious = yytext[0] = lex_input();
		if (yyprevious>0)
			lex_output(yyprevious);
#endif
		yylastch=yytext;
# ifdef LEXDEBUG
		if(debug)putchar('\n');
# endif
		}
	}
#if defined(__cplusplus) || defined(__STDC__)
int yyback(int *p, int m)
#else
yyback(p, m)
	int *p;
#endif
{
	if (p==0) return(0);
	while (*p) {
		if (*p++ == m)
			return(1);
	}
	return(0);
}
	/* the following are only used in the lex library */
#if defined(__cplusplus) || defined(__STDC__)
int yyinput(void)
#else
yyinput()
#endif
{
#ifndef __cplusplus
	return(input());
#else
	return(lex_input());
#endif
	}
#if defined(__cplusplus) || defined(__STDC__)
void yyoutput(int c)
#else
yyoutput(c)
  int c; 
#endif
{
#ifndef __cplusplus
	output(c);
#else
	lex_output(c);
#endif
	}
#if defined(__cplusplus) || defined(__STDC__)
void yyunput(int c)
#else
yyunput(c)
   int c; 
#endif
{
	unput(c);
	}