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

📄 main.c

📁 C++版 词法分析、语法分析器
💻 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;
			if(*includefilename=='\0')
				flexerror("no space is allowed between -g and a file name");
		    goto get_next_arg;
		case 'h':
		    if ( i != 1 )
			flexerror( "-h flag must be given separately" );

		    headerfilename = arg + i + 1;
			if(*headerfilename=='\0')
				flexerror("no space is allowed between -h and a file name");
		    goto get_next_arg;
		case 'o':
		    if ( i != 1 )
			flexerror( "-o flag must be given separately" );

		    outputfilename = arg + i + 1;
			if(*outputfilename=='\0')
				flexerror("no space is allowed between -o and a file name");
		    goto get_next_arg;

		case 'H':
		    if ( i != 1 )
			flexerror( "-H flag must be given separately" );

		    skelheaderfilename = arg + i + 1;
			if(*skelheaderfilename=='\0')
				flexerror("no space is allowed between -H and a file name");
		    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 )
	{
#ifdef	WIN32
		skelname = computeFileName( DEFAULT_SKELETON_FILE );
#else
		skelname = DEFAULT_SKELETON_FILE;
#endif
	}

    if ( ! skelheaderfilename )
	{
#ifdef	WIN32
		skelheaderfilename = computeFileName( DEFAULT_SKELETONHEADER_FILE );
#else
		skelheaderfilename=DEFAULT_SKELETONHEADER_FILE;
#endif
	}
    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];

#if !defined(SHORT_FILE_NAMES) && !defined(WIN32)
	(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 + -