⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 main.c

📁 生成C++的词法/语法分析的Flex语法分析器
💻 C
📖 第 1 页 / 共 2 页
字号:
		    for ( ++i; arg[i] != '\0'; ++i )			switch ( arg[i] )			    {			    case 'e':				useecs = true;				break;			    case 'F':				fullspd = true;				break;			    case 'f':				fulltbl = true;				break;			    case 'm':				usemecs = true;				break;			    default:				fprintf(stderr, "unknown -C option '%c'",					(int) arg[i] );				flexinfo(1);				break;			    }		    goto get_next_arg;		case 'd':		    ddebug = true;		    break;		case 'f':		    useecs = usemecs = false;		    fulltbl = true;		    break;		case 'F':		    useecs = usemecs = false;		    fullspd = true;		    break;		case 'g':		    if ( i != 1 )			flexerror( "-g flag must be given separately" );		    includefilename = arg + i + 1;		    goto get_next_arg;		case 'h':		    if ( i != 1 )			flexerror( "-h flag must be given separately" );		    headerfilename = arg + i + 1;		    goto get_next_arg;		case 'o':		    if ( i != 1 )			flexerror( "-o flag must be given separately" );		    outputfilename = arg + i + 1;		    goto get_next_arg;		case 'H':		    if ( i != 1 )			flexerror( "-H flag must be given separately" );		    skelheaderfilename = arg + i + 1;		    goto get_next_arg;		case 'I':		    interactive = true;		    break;		case 'i':		    caseins = true;		    break;		case 'L':		    gen_line_dirs = false;		    break;		case 'n':		    /* stupid do-nothing deprecated option */		    break;		case 'p':		    performance_report = true;		    break;		case 'S':		    if ( i != 1 )			flexerror( "-S flag must be given separately" );		    skelname = arg + i + 1;		    goto get_next_arg;		case 's':		    spprdflt = true;		    break;		case 't':		    use_stdout = true;		    break;		case 'T':		    trace = true;		    break;		case 'v':		    printstats = true;		    break;		case '8':		    csize = CSIZE;		    break;		case '?':		    flexinfo(0);		    break;		default:		    fprintf(stderr, "unknown flag '%c'", (int) arg[i] );		    flexinfo(1);		    break;		}get_next_arg: /* used by -C and -S flags in lieu of a "continue 2" control */	;	}    if ( (fulltbl || fullspd) && usemecs )	flexerror( "full table and -Cm don't make sense together" );    if ( (fulltbl || fullspd) && interactive )	flexerror( "full table and -I are (currently) incompatible" );    if ( fulltbl && fullspd )	flexerror( "full table and -F are mutually exclusive" );    if( use_stdout && outputfilename )	flexerror( "-t (generate to stdout) and -o (generate to file) are mutually exclusive" );    if ( ! skelname )	{	skelname=DEFAULT_SKELETON_FILE;	}    if ( ! skelheaderfilename )	{	skelheaderfilename=DEFAULT_SKELETONHEADER_FILE;	}    if ( ! use_stdout )	{FILE *prev_stdout;	if(outputfilename && outputfilename[0] ) outfile=outputfilename;	prev_stdout = freopen( outfile, "w", stdout );	if ( prev_stdout == NULL )	    lerrsf( "could not create %s", outfile );	outfile_created = 1;	}    num_input_files = argc;    input_files = argv;    set_input_file( num_input_files > 0 ? input_files[0] : NULL );    if ( (skelheaderfile = fopen( skelheaderfilename, "r" )) == NULL )#ifdef _MSDOS     if(getenv("INIT")!=NULL)     {char *t;      t=malloc(strlen(getenv("INIT"))+strlen(skelheaderfilename)+2);      strcpy(t,getenv("INIT"));      strcat(t,"/");      strcat(t,skelheaderfilename);      skelheaderfilename=t;      if((skelheaderfile = fopen( skelheaderfilename, "r" )) == NULL)	lerrsf( "can't open skeleton header file %s", skelheaderfilename );     }     else#endif	lerrsf( "can't open skeleton header file %s", skelheaderfilename );    if(headerfilename==NULL) headerfile=stdout;    else       {      if(headerfilename[0]=='\0')       {char **suffix;	headerfilename=malloc(strlen(outfile)+3);	strcpy(headerfilename,outfile);	for(suffix=c_suffixes;*suffix;suffix++)	/* try to detect .c .cpp options */	  {if(strlen(headerfilename)>strlen(*suffix)	      && strcmp(headerfilename+		   strlen(headerfilename)-strlen(*suffix),*suffix)==0	      )	    { *(headerfilename+strlen(headerfilename)-strlen(*suffix))='\0';	     break;}	  };	strcat(headerfilename,".h");     	}      if(includefilename==NULL)	 includefilename=headerfilename;      if ( (headerfile = fopen( headerfilename, "w" )) == NULL )	lerrsf( "can't open header file %s", headerfilename );      };    if ( backtrack_report )	{#ifndef SHORT_FILE_NAMES	backtrack_file = fopen( "lex.backtrack", "w" );#else	backtrack_file = fopen( "lex.bck", "w" );#endif	if ( backtrack_file == NULL )	    flexerror( "could not create lex.backtrack" );	}    else	backtrack_file = NULL;    lastccl = 0;    lastsc = 0;    /* initialize the statistics */    if ( (skelfile = fopen( skelname, "r" )) == NULL )#ifdef _MSDOS       if(getenv("INIT")!=NULL)     {char *t;      t=malloc(strlen(getenv("INIT"))+strlen(skelname)+2);      strcpy(t,getenv("INIT"));      strcat(t,"/");      strcat(t,skelname);      skelname=t;      if((skelfile = fopen(skelname , "r" )) == NULL)	lerrsf( "can't open skeleton file %s", skelname );     }     else#endif	lerrsf( "can't open skeleton file %s", skelname );    if(tmp_action)     {char *ftmp;      ftmp=malloc(strlen(tmp_action)+1+32);      strcpy(ftmp,tmp_action);#ifndef SHORT_FILE_NAMES	(void) strcat( ftmp, "/flexXXXXXX" );#else	(void) strcpy( ftmp, "/flXXXXXX.tmp" );#endif      action_file_name=ftmp;      (void) mktemp( action_file_name );     }    else     {#ifdef _MSDOS      action_file_name=_tempnam(".","flex");#else#ifdef SYS_V    action_file_name = tmpnam( NULL );#endif#endif     }    if ( action_file_name == NULL )	{	static char temp_action_file_name[32];#ifndef SHORT_FILE_NAMES	(void) strcpy( temp_action_file_name, "/tmp/flexXXXXXX" );#else	(void) strcpy( temp_action_file_name, "flXXXXXX.tmp" );#endif	(void) mktemp( temp_action_file_name );	action_file_name = temp_action_file_name;	}    if ( (temp_action_file = fopen( action_file_name, "w" )) == NULL )	lerrsf( "can't open temporary action file %s", action_file_name );    lastdfa = lastnfa = num_rules = numas = numsnpairs = tmpuses = 0;    numecs = numeps = eps2 = num_reallocs = hshcol = dfaeql = totnst = 0;    numuniq = numdup = hshsave = eofseen = datapos = dataline = 0;    num_backtracking = onesp = numprots = 0;    variable_trailing_context_rules = bol_needed = false;    linenum = sectnum = 1;    firstprot = NIL;    /* used in mkprot() so that the first proto goes in slot 1     * of the proto queue     */    lastprot = 1;    if ( useecs )	{ /* set up doubly-linked equivalence classes */	/* We loop all the way up to csize, since ecgroup[csize] is the	 * position used for NUL characters	 */	ecgroup[1] = NIL;	for ( i = 2; i <= csize; ++i )	    {	    ecgroup[i] = i - 1;	    nextecm[i - 1] = i;	    }	nextecm[csize] = NIL;	}    else	{ /* put everything in its own equivalence class */	for ( i = 1; i <= csize; ++i )	    {	    ecgroup[i] = i;	    nextecm[i] = BAD_SUBSCRIPT; /* to catch errors */	    }	}    set_up_initial_allocations();    } int flexinfo(status) int status; {    fprintf(stderr,"Syntax  :  flex  [options...] inp_file\n");    fprintf(stderr,"Function: fast lexical analyzer generator C/C++  V%s\n",flex_version);    fprintf(stderr,"Options : \n");    fprintf(stderr,"	-a dir_path  : directory path for temporary files\n");    fprintf(stderr,"	-b  : generate backtracking information to lex.backtrack\n");    fprintf(stderr,"	-c  : compressed table, no equiv., no meta equiv.classes\n");    fprintf(stderr,"	-C  : compressed table, no equiv., no meta equiv.classes\n");    fprintf(stderr,"	-Ce : compressed table, with equivalence classes\n");    fprintf(stderr,"	-Cem: compressed table, with equivalence and meta equiv. classes\n");    fprintf(stderr,"	-Cm: compressed table, with meta equivalence classes\n");    fprintf(stderr,"	-Cm: compressed table, with meta equivalence classes\n");    fprintf(stderr,"	-CF :  alternate fast table\n");    fprintf(stderr,"	-Cf :  full table\n");    fprintf(stderr,"	-CFe : alternate fast table, with equivalence classes\n");    fprintf(stderr,"	-Cfe : full table, with equivalence classes\n");    fprintf(stderr,"	-F  : fast table\n");    fprintf(stderr,"	-f  : full (not compressed) table\n");    fprintf(stderr,"	-d  : generate debugging scanner\n");    fprintf(stderr,"	-I  : generate interactive scanner\n");    fprintf(stderr,"	-i  : generate case-insensitive scanner\n");    fprintf(stderr,"	-L  : supress #line directives\n"); /*   fprintf(stderr,"	-n hexnum : generate scanner using <hexnum> as newline char.\n");*/    fprintf(stderr,"	-p  : generate performance report to stderr\n");    fprintf(stderr,"	-S skeleton_path : file path for skeleton file\n");    fprintf(stderr,"	-H header_skeleton_path : file path for header skeleton file\n");    fprintf(stderr,"	-s  : suppress echo of unmatched scanner input to stdout\n");    fprintf(stderr,"	-T  : run flex in trace mode\n");    fprintf(stderr,"	-t  : place result on stdout \n");    fprintf(stderr,"	-v  : print statistics of generated scanner\n");    fprintf(stderr,"	-o code_file  : set name of output code file\n");    fprintf(stderr,"	-h [header_file]  : generate a separate header_file\n");    fprintf(stderr,"	-g include_file  : name of header to include (default= same as -h)\n");    fprintf(stderr,"	-?   : this help\n");    fprintf(stderr,"	default =  -Cem\n");    exit(status);    return 0; }/* readin - read in the rules section of the input file(s) * * synopsis *    readin(); */void readin()    {        char *ch_type;    if(headerfilename!=NULL)     {char symb[32],ch;      char *p=headerfilename;      int i=0;symb[0]='\0';      while(*p)        {	if(*p=='/'#ifdef MS_DOS	   || *p=='\\' || *p==':'#endif	   ) {symb[0]='\0';i=0;}	else {	 if((*p>='A' && *p<='Z')||((*p>='a' && *p<='z'))             ||((*p>='0' && *p<='9'))||(ch=='_'))           ch=*p;	 else           ch='_';	 if(i<sizeof(symb)-1)	  {symb[i++]=ch;symb[i]='\0';}	 }	p++;        };      fprintf(headerfile,"#ifndef FLEX_HEADER_%s\n",symb );      fprintf(headerfile,"#define FLEX_HEADER_%s\n",symb );     }     if ( csize == 256 )       ch_type="unsigned char";     else       ch_type="char";    if ( ddebug )      fprintf(stdout, "#define FLEX_DEBUG\n" );    fprintf(stdout, "#define YY_CHAR %s\n",ch_type );    skelout();    line_directive_out( stdout );    if ( yyparse() )	{	pinpoint_message( "fatal parse error" );	flexend( 1 );	}    if ( xlation )	{	numecs = ecs_from_xlation( ecgroup );	useecs = true;	}    else if ( useecs )	numecs = cre8ecs( nextecm, ecgroup, csize );    else	numecs = csize;    /* now map the equivalence class for NUL to its expected place */    ecgroup[0] = ecgroup[csize];    NUL_ec = abs( ecgroup[0] );    if ( useecs )	ccl2ecl();    line_directive_out( headerfile );    if(headerfilename!=NULL) fprintf(headerfile,"#endif\n" );    header_skeleton_out();    }/* set_up_initial_allocations - allocate memory for internal tables */void set_up_initial_allocations()    {    current_mns = INITIAL_MNS;    firstst = allocate_integer_array( current_mns );    lastst = allocate_integer_array( current_mns );    finalst = allocate_integer_array( current_mns );    transchar = allocate_integer_array( current_mns );    trans1 = allocate_integer_array( current_mns );    trans2 = allocate_integer_array( current_mns );    accptnum = allocate_integer_array( current_mns );    assoc_rule = allocate_integer_array( current_mns );    state_type = allocate_integer_array( current_mns );    current_max_rules = INITIAL_MAX_RULES;    rule_type = allocate_integer_array( current_max_rules );    rule_linenum = allocate_integer_array( current_max_rules );    current_max_scs = INITIAL_MAX_SCS;    scset = allocate_integer_array( current_max_scs );    scbol = allocate_integer_array( current_max_scs );    scxclu = allocate_integer_array( current_max_scs );    sceof = allocate_integer_array( current_max_scs );    scname = allocate_char_ptr_array( current_max_scs );    actvsc = allocate_integer_array( current_max_scs );    current_maxccls = INITIAL_MAX_CCLS;    cclmap = allocate_integer_array( current_maxccls );    ccllen = allocate_integer_array( current_maxccls );    cclng = allocate_integer_array( current_maxccls );    current_max_ccl_tbl_size = INITIAL_MAX_CCL_TBL_SIZE;    ccltbl = allocate_character_array( current_max_ccl_tbl_size );    current_max_dfa_size = INITIAL_MAX_DFA_SIZE;    current_max_xpairs = INITIAL_MAX_XPAIRS;    nxt = allocate_integer_array( current_max_xpairs );    chk = allocate_integer_array( current_max_xpairs );    current_max_template_xpairs = INITIAL_MAX_TEMPLATE_XPAIRS;    tnxt = allocate_integer_array( current_max_template_xpairs );    current_max_dfas = INITIAL_MAX_DFAS;    base = allocate_integer_array( current_max_dfas );    def = allocate_integer_array( current_max_dfas );    dfasiz = allocate_integer_array( current_max_dfas );    accsiz = allocate_integer_array( current_max_dfas );    dhash = allocate_integer_array( current_max_dfas );    dss = allocate_int_ptr_array( current_max_dfas );    dfaacc = allocate_dfaacc_union( current_max_dfas );    nultrans = (int *) 0;    }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -