亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? parse.c

?? 編譯原理(Flex):生成詞法和語法分析程序的源代碼的程序。
?? C
?? 第 1 頁 / 共 3 頁
字號:

void format_pinpoint_message( msg, arg )
char msg[], arg[];
	{
	char errmsg[MAXLINE];

	(void) sprintf( errmsg, msg, arg );
	pinpoint_message( errmsg );
	}


/* pinpoint_message - write out a message, pinpointing its location */

void pinpoint_message( str )
char str[];
	{
	line_pinpoint( str, linenum );
	}


/* line_warning - report a warning at a given line, unless -w was given */

void line_warning( str, line )
char str[];
int line;
	{
	char warning[MAXLINE];

	if ( ! nowarn )
		{
		sprintf( warning, "warning, %s", str );
		line_pinpoint( warning, line );
		}
	}


/* line_pinpoint - write out a message, pinpointing it at the given line */

void line_pinpoint( str, line )
char str[];
int line;
	{
	fprintf( stderr, "\"%s\", line %d: %s\n", infilename, line, str );
	}


/* yyerror - eat up an error message from the parser;
 *	     currently, messages are ignore
 */

void yyerror( msg )
char msg[];
	{
	}
#line 541 "y.tab.c"
#define YYABORT goto yyabort
#define YYREJECT goto yyabort
#define YYACCEPT goto yyaccept
#define YYERROR goto yyerrlab
int
yyparse()
{
    register int yym, yyn, yystate;
#if YYDEBUG
    register char *yys;
    extern char *getenv();

    if (yys = getenv("YYDEBUG"))
    {
        yyn = *yys;
        if (yyn >= '0' && yyn <= '9')
            yydebug = yyn - '0';
    }
#endif

    yynerrs = 0;
    yyerrflag = 0;
    yychar = (-1);

    yyssp = yyss;
    yyvsp = yyvs;
    *yyssp = yystate = 0;

yyloop:
    if (yyn = yydefred[yystate]) goto yyreduce;
    if (yychar < 0)
    {
        if ((yychar = yylex()) < 0) yychar = 0;
#if YYDEBUG
        if (yydebug)
        {
            yys = 0;
            if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
            if (!yys) yys = "illegal-symbol";
            printf("%sdebug: state %d, reading %d (%s)\n",
                    YYPREFIX, yystate, yychar, yys);
        }
#endif
    }
    if ((yyn = yysindex[yystate]) && (yyn += yychar) >= 0 &&
            yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
    {
#if YYDEBUG
        if (yydebug)
            printf("%sdebug: state %d, shifting to state %d\n",
                    YYPREFIX, yystate, yytable[yyn]);
#endif
        if (yyssp >= yyss + yystacksize - 1)
        {
            goto yyoverflow;
        }
        *++yyssp = yystate = yytable[yyn];
        *++yyvsp = yylval;
        yychar = (-1);
        if (yyerrflag > 0)  --yyerrflag;
        goto yyloop;
    }
    if ((yyn = yyrindex[yystate]) && (yyn += yychar) >= 0 &&
            yyn <= YYTABLESIZE && yycheck[yyn] == yychar)
    {
        yyn = yytable[yyn];
        goto yyreduce;
    }
    if (yyerrflag) goto yyinrecovery;
#ifdef lint
    goto yynewerror;
#endif
yynewerror:
    yyerror("syntax error");
#ifdef lint
    goto yyerrlab;
#endif
yyerrlab:
    ++yynerrs;
yyinrecovery:
    if (yyerrflag < 3)
    {
        yyerrflag = 3;
        for (;;)
        {
            if ((yyn = yysindex[*yyssp]) && (yyn += YYERRCODE) >= 0 &&
                    yyn <= YYTABLESIZE && yycheck[yyn] == YYERRCODE)
            {
#if YYDEBUG
                if (yydebug)
                    printf("%sdebug: state %d, error recovery shifting\
 to state %d\n", YYPREFIX, *yyssp, yytable[yyn]);
#endif
                if (yyssp >= yyss + yystacksize - 1)
                {
                    goto yyoverflow;
                }
                *++yyssp = yystate = yytable[yyn];
                *++yyvsp = yylval;
                goto yyloop;
            }
            else
            {
#if YYDEBUG
                if (yydebug)
                    printf("%sdebug: error recovery discarding state %d\n",
                            YYPREFIX, *yyssp);
#endif
                if (yyssp <= yyss) goto yyabort;
                --yyssp;
                --yyvsp;
            }
        }
    }
    else
    {
        if (yychar == 0) goto yyabort;
#if YYDEBUG
        if (yydebug)
        {
            yys = 0;
            if (yychar <= YYMAXTOKEN) yys = yyname[yychar];
            if (!yys) yys = "illegal-symbol";
            printf("%sdebug: state %d, error recovery discards token %d (%s)\n",
                    YYPREFIX, yystate, yychar, yys);
        }
#endif
        yychar = (-1);
        goto yyloop;
    }
yyreduce:
#if YYDEBUG
    if (yydebug)
        printf("%sdebug: state %d, reducing by rule %d (%s)\n",
                YYPREFIX, yystate, yyn, yyrule[yyn]);
#endif
    yym = yylen[yyn];
    yyval = yyvsp[1-yym];
    switch (yyn)
    {
case 1:
#line 113 "./parse.y"
{ /* add default rule */
			int def_rule;

			pat = cclinit();
			cclnegate( pat );

			def_rule = mkstate( -pat );

			/* Remember the number of the default rule so we
			 * don't generate "can't match" warnings for it.
			 */
			default_rule = num_rules;

			finish_rule( def_rule, false, 0, 0 );

			for ( i = 1; i <= lastsc; ++i )
				scset[i] = mkbranch( scset[i], def_rule );

			if ( spprdflt )
				add_action(
				"YY_FATAL_ERROR( \"flex scanner jammed\" )" );
			else
				add_action( "ECHO" );

			add_action( ";\n\tYY_BREAK\n" );
			}
break;
case 2:
#line 142 "./parse.y"
{ /* initialize for processing rules */

			/* Create default DFA start condition. */
			scinstal( "INITIAL", false );
			}
break;
case 6:
#line 153 "./parse.y"
{ synerr( "unknown error processing section 1" ); }
break;
case 7:
#line 157 "./parse.y"
{
			check_options();
			scon_stk = allocate_integer_array( lastsc + 1 );
			scon_stk_ptr = 0;
			}
break;
case 8:
#line 165 "./parse.y"
{ xcluflg = false; }
break;
case 9:
#line 168 "./parse.y"
{ xcluflg = true; }
break;
case 10:
#line 172 "./parse.y"
{ scinstal( nmstr, xcluflg ); }
break;
case 11:
#line 175 "./parse.y"
{ scinstal( nmstr, xcluflg ); }
break;
case 12:
#line 178 "./parse.y"
{ synerr( "bad start condition list" ); }
break;
case 16:
#line 189 "./parse.y"
{
			outfilename = copy_string( nmstr );
			did_outfilename = 1;
			}
break;
case 17:
#line 194 "./parse.y"
{ prefix = copy_string( nmstr ); }
break;
case 18:
#line 196 "./parse.y"
{ yyclass = copy_string( nmstr ); }
break;
case 19:
#line 200 "./parse.y"
{ scon_stk_ptr = yyvsp[-3]; }
break;
case 20:
#line 202 "./parse.y"
{ scon_stk_ptr = yyvsp[-3]; }
break;
case 22:
#line 207 "./parse.y"
{
			/* Initialize for a parse of one rule. */
			trlcontxt = variable_trail_rule = varlength = false;
			trailcnt = headcnt = rulelen = 0;
			current_state_type = STATE_NORMAL;
			previous_continued_action = continued_action;
			in_rule = true;

			new_rule();
			}
break;
case 23:
#line 220 "./parse.y"
{
			pat = yyvsp[0];
			finish_rule( pat, variable_trail_rule,
				headcnt, trailcnt );

			if ( scon_stk_ptr > 0 )
				{
				for ( i = 1; i <= scon_stk_ptr; ++i )
					scbol[scon_stk[i]] =
						mkbranch( scbol[scon_stk[i]],
								pat );
				}

			else
				{
				/* Add to all non-exclusive start conditions,
				 * including the default (0) start condition.
				 */

				for ( i = 1; i <= lastsc; ++i )
					if ( ! scxclu[i] )
						scbol[i] = mkbranch( scbol[i],
									pat );
				}

			if ( ! bol_needed )
				{
				bol_needed = true;

				if ( performance_report > 1 )
					pinpoint_message(
			"'^' operator results in sub-optimal performance" );
				}
			}
break;
case 24:
#line 256 "./parse.y"
{
			pat = yyvsp[0];
			finish_rule( pat, variable_trail_rule,
				headcnt, trailcnt );

			if ( scon_stk_ptr > 0 )
				{
				for ( i = 1; i <= scon_stk_ptr; ++i )
					scset[scon_stk[i]] =
						mkbranch( scset[scon_stk[i]],
								pat );
				}

			else
				{
				for ( i = 1; i <= lastsc; ++i )
					if ( ! scxclu[i] )
						scset[i] =
							mkbranch( scset[i],
								pat );
				}
			}
break;
case 25:
#line 280 "./parse.y"
{
			if ( scon_stk_ptr > 0 )
				build_eof_action();
	
			else
				{
				/* This EOF applies to all start conditions
				 * which don't already have EOF actions.
				 */
				for ( i = 1; i <= lastsc; ++i )
					if ( ! sceof[i] )
						scon_stk[++scon_stk_ptr] = i;

				if ( scon_stk_ptr == 0 )
					warn(
			"all start conditions already have <<EOF>> rules" );

				else
					build_eof_action();
				}
			}
break;
case 26:
#line 303 "./parse.y"
{ synerr( "unrecognized rule" ); }
break;
case 27:
#line 307 "./parse.y"
{ yyval = scon_stk_ptr; }
break;
case 28:
#line 311 "./parse.y"
{ yyval = yyvsp[-2]; }
break;
case 29:
#line 314 "./parse.y"
{
			yyval = scon_stk_ptr;

			for ( i = 1; i <= lastsc; ++i )
				{
				int j;

				for ( j = 1; j <= scon_stk_ptr; ++j )
					if ( scon_stk[j] == i )
						break;

				if ( j > scon_stk_ptr )
					scon_stk[++scon_stk_ptr] = i;
				}
			}
break;
case 30:
#line 331 "./parse.y"
{ yyval = scon_stk_ptr; }
break;
case 33:
#line 339 "./parse.y"
{ synerr( "bad start condition list" ); }
break;
case 34:
#line 343 "./parse.y"
{
			if ( (scnum = sclookup( nmstr )) == 0 )
				format_pinpoint_message(
					"undeclared start condition %s",
					nmstr );
			else
				{
				for ( i = 1; i <= scon_stk_ptr; ++i )
					if ( scon_stk[i] == scnum )
						{
						format_warn(
							"<%s> specified twice",
							scname[scnum] );
						break;
						}

				if ( i > scon_stk_ptr )
					scon_stk[++scon_stk_ptr] = scnum;
				}
			}
break;
case 35:
#line 366 "./parse.y"
{
			if ( transchar[lastst[yyvsp[0]]] != SYM_EPSILON )
				/* Provide final transition \now/ so it
				 * will be marked as a trailing context
				 * state.
				 */
				yyvsp[0] = link_machines( yyvsp[0],
						mkstate( SYM_EPSILON ) );

			mark_beginning_as_normal( yyvsp[0] );
			current_state_type = STATE_NORMAL;

			if ( previous_continued_action )
				{
				/* We need to treat this as variable trailing
				 * context so that the backup does not happen
				 * in the action but before the action switch
				 * statement.  If the backup happens in the
				 * action, then the rules "falling into" this
				 * one's action will *also* do the backup,
				 * erroneously.
				 */
				if ( ! varlength || headcnt != 0 )
					warn(
		"trailing context made variable due to preceding '|' action" );

				/* Mark as variable. */
				varlength = true;
				headcnt = 0;
				}

			if ( lex_compat || (varlength && headcnt == 0) )
				{ /* variable trailing context rule */
				/* Mark the first part of the rule as the
				 * accepting "head" part of a trailing
				 * context rule.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色av一区二区| 久久久亚洲高清| 亚洲精品大片www| 91成人看片片| 视频一区欧美日韩| 日韩精品一区二区三区在线播放| 精品一区二区三区影院在线午夜| 天堂一区二区在线| 日韩视频在线你懂得| 激情欧美日韩一区二区| 国产欧美日本一区视频| 在线一区二区三区四区五区| 日本一区中文字幕| 久久久综合精品| 色综合av在线| 美女一区二区视频| 国产精品久久久久永久免费观看| 色婷婷精品久久二区二区蜜臀av| 午夜欧美2019年伦理| 久久精品视频一区| 色噜噜狠狠成人中文综合| 美女任你摸久久 | 在线亚洲精品福利网址导航| 亚洲综合在线第一页| 日韩欧美国产三级电影视频| 国产成人免费视频网站 | 国产日韩精品一区| 日本乱码高清不卡字幕| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲精品在线网站| 欧美色网一区二区| 国产成人免费在线观看| 日韩国产一区二| 国产精品国产精品国产专区不片| 欧美蜜桃一区二区三区| 粉嫩av亚洲一区二区图片| 亚洲国产精品久久久久婷婷884| 久久精品亚洲乱码伦伦中文| 欧美色倩网站大全免费| 国产经典欧美精品| 日本欧美肥老太交大片| 国产精品激情偷乱一区二区∴| 欧美一区二区三区免费大片| 色综合久久久网| 国产xxx精品视频大全| 天天免费综合色| 亚洲柠檬福利资源导航| 91精品国产欧美一区二区| 在线观看欧美精品| 91丨九色丨蝌蚪富婆spa| 国产一区二区三区高清播放| 日韩福利视频导航| 一区二区三区**美女毛片| 国产精品素人一区二区| 精品欧美一区二区在线观看 | 日韩欧美一级片| 欧美吞精做爰啪啪高潮| 97精品电影院| 国产不卡视频一区| 国产精品99久久久久久久vr| 国产一区激情在线| 91麻豆免费看| 9i看片成人免费高清| 国产成人在线看| 国产精品自拍一区| 狠狠色狠狠色综合| 另类的小说在线视频另类成人小视频在线 | 激情综合色播激情啊| 日韩激情在线观看| 丝袜亚洲另类欧美综合| 亚洲成人在线免费| 午夜精品福利一区二区蜜股av | 色综合婷婷久久| 成人激情免费电影网址| 波多野洁衣一区| 成人高清视频在线| 99精品视频一区| 91丨porny丨国产| 色综合久久综合网欧美综合网 | aa级大片欧美| 91丨porny丨首页| 色美美综合视频| 欧美色视频一区| 欧美一区二区日韩一区二区| 91精品国产全国免费观看| 欧美一区二区成人| 精品国产三级a在线观看| 久久中文娱乐网| 欧美—级在线免费片| 中文字幕一区二区视频| 亚洲欧美日本在线| 亚洲国产一区二区三区| 日韩二区三区四区| 国产一区二区不卡在线| 成人午夜精品一区二区三区| 97精品国产露脸对白| 欧美性感一类影片在线播放| 欧美一区二区三区视频在线观看 | 中文字幕一区二区三中文字幕| 中文字幕中文字幕在线一区| 一区二区三区在线视频免费 | 欧美在线一区二区| 欧美日韩激情一区二区三区| 日韩免费观看高清完整版在线观看| 欧美电影免费观看完整版| 中文字幕第一页久久| 亚洲日本成人在线观看| 日韩电影免费一区| 国产成人精品免费一区二区| 91福利资源站| 久久理论电影网| 一级做a爱片久久| 久久精品国产亚洲aⅴ| 国产日韩av一区| 一区二区三区在线播放| 美女看a上一区| 成人app网站| 91精品久久久久久久91蜜桃| 国产片一区二区三区| 亚洲一级电影视频| 国产一区二区免费看| 欧美吻胸吃奶大尺度电影 | 国产精品久久久久久一区二区三区| 亚洲精品乱码久久久久久久久 | 亚洲国产wwwccc36天堂| 国产精品69久久久久水密桃 | 日韩午夜在线播放| 成人免费一区二区三区视频| 久久精品国产精品亚洲精品 | 成人免费毛片嘿嘿连载视频| 欧美性感一类影片在线播放| 国产精品日韩成人| 麻豆国产精品777777在线| 在线视频你懂得一区二区三区| 久久久久国色av免费看影院| 偷拍亚洲欧洲综合| 色就色 综合激情| 欧美国产日韩精品免费观看| 久久er99精品| 欧美色精品在线视频| 亚洲日本成人在线观看| 福利电影一区二区| 精品国产成人系列| 日韩电影在线观看电影| 色婷婷亚洲一区二区三区| 国产三级精品三级在线专区| 日本不卡不码高清免费观看| 欧美在线三级电影| 亚洲欧洲精品成人久久奇米网| 国产suv一区二区三区88区| 日韩一区二区三| 天堂午夜影视日韩欧美一区二区| 91麻豆国产精品久久| 国产精品视频观看| 国产91在线|亚洲| 久久综合久久综合久久综合| 美女视频一区在线观看| 911精品国产一区二区在线| 亚洲一区二区三区中文字幕| 色天天综合久久久久综合片| 中文字幕中文字幕一区二区| 国产91在线观看| 中文字幕欧美一区| 91丨porny丨在线| 亚洲美女屁股眼交| 欧美日精品一区视频| 亚洲成av人片在线观看| 欧美日韩中文字幕一区| 午夜欧美视频在线观看| 91精品国产综合久久精品性色| 日韩二区三区四区| 精品欧美乱码久久久久久| 国产精品99久久不卡二区| 中国色在线观看另类| av激情综合网| 成人a免费在线看| 国产精品三级电影| 在线看不卡av| 视频在线观看国产精品| 精品久久久网站| 国产不卡在线视频| 亚洲精品欧美二区三区中文字幕| 在线免费观看视频一区| 日韩av中文字幕一区二区 | 欧美日韩三级视频| 三级成人在线视频| 精品国产成人系列| 波多野结衣在线aⅴ中文字幕不卡| 亚洲精品久久久久久国产精华液| 欧美无砖专区一中文字| 精品一区在线看| 国产精品电影院| 欧美日韩国产影片| 国产精品综合一区二区三区| 国产精品久久久久婷婷| 欧美亚洲动漫制服丝袜| 老汉av免费一区二区三区| 中文字幕久久午夜不卡| 欧美主播一区二区三区美女| 免费观看久久久4p|