Split generation of c and h files in separate functions. Also relevant
changes for the generated parse tree. git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@4430 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
		@@ -45,7 +45,6 @@ RCSID("$Id$");
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int numerror;
 | 
					int numerror;
 | 
				
			||||||
extern FILE *yyin;
 | 
					extern FILE *yyin;
 | 
				
			||||||
FILE *c_file, *h_file;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
extern void yyparse(void);
 | 
					extern void yyparse(void);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -64,16 +63,18 @@ extern int yydebug = 1;
 | 
				
			|||||||
char *filename;
 | 
					char *filename;
 | 
				
			||||||
char hfn[128];
 | 
					char hfn[128];
 | 
				
			||||||
char cfn[128];
 | 
					char cfn[128];
 | 
				
			||||||
char fn[128];
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
void prologue()
 | 
					struct error_code *codes;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int
 | 
				
			||||||
 | 
					generate_c(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    char *p;
 | 
					    int n;
 | 
				
			||||||
    snprintf(fn, sizeof(fn), "__%s__", hfn);
 | 
					    struct error_code *ec;
 | 
				
			||||||
    for(p = fn; *p; p++)
 | 
					    FILE *c_file = fopen(cfn, "w");
 | 
				
			||||||
	if(!isalnum(*p))
 | 
					    if(c_file == NULL)
 | 
				
			||||||
	    *p = '_';
 | 
						return 1;
 | 
				
			||||||
    
 | 
					
 | 
				
			||||||
    fprintf(c_file, "/* Generated from %s */\n", filename);
 | 
					    fprintf(c_file, "/* Generated from %s */\n", filename);
 | 
				
			||||||
    if(id_str) 
 | 
					    if(id_str) 
 | 
				
			||||||
	fprintf(c_file, "/* %s */\n", id_str);
 | 
						fprintf(c_file, "/* %s */\n", id_str);
 | 
				
			||||||
@@ -85,6 +86,56 @@ void prologue()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    fprintf(c_file, "static const char *text[] = {\n");
 | 
					    fprintf(c_file, "static const char *text[] = {\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for(ec = codes, n = 0; ec; ec = ec->next, n++) {
 | 
				
			||||||
 | 
						while(n < ec->number) {
 | 
				
			||||||
 | 
						    fprintf(c_file, "\t/* %03d */ \"Reserved %s error (%d)\",\n",
 | 
				
			||||||
 | 
							    n, name, n);
 | 
				
			||||||
 | 
						    n++;
 | 
				
			||||||
 | 
						    
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						fprintf(c_file, "\t/* %03d */ \"%s\",\n", ec->number, ec->string);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    fprintf(c_file, "\tNULL\n");
 | 
				
			||||||
 | 
					    fprintf(c_file, "};\n");
 | 
				
			||||||
 | 
					    fprintf(c_file, "\n");
 | 
				
			||||||
 | 
					    fprintf(c_file, 
 | 
				
			||||||
 | 
						    "void initialize_%s_error_table_r(struct error_table **list)\n", 
 | 
				
			||||||
 | 
						    name);
 | 
				
			||||||
 | 
					    fprintf(c_file, "{\n");
 | 
				
			||||||
 | 
					    fprintf(c_file, 
 | 
				
			||||||
 | 
						    "    initialize_error_table_r(list, text, "
 | 
				
			||||||
 | 
						    "%s_num_errors, ERROR_TABLE_BASE_%s);\n", name, name);
 | 
				
			||||||
 | 
					    fprintf(c_file, "}\n");
 | 
				
			||||||
 | 
					    fprintf(c_file, "\n");
 | 
				
			||||||
 | 
					    fprintf(c_file, "void initialize_%s_error_table(void)\n", name);
 | 
				
			||||||
 | 
					    fprintf(c_file, "{\n");
 | 
				
			||||||
 | 
					    fprintf(c_file,
 | 
				
			||||||
 | 
						    "    init_error_table(text, ERROR_TABLE_BASE_%s, "
 | 
				
			||||||
 | 
						    "%s_num_errors);\n", name, name);
 | 
				
			||||||
 | 
					    fprintf(c_file, "}\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    fclose(c_file);
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int
 | 
				
			||||||
 | 
					generate_h(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    int n;
 | 
				
			||||||
 | 
					    struct error_code *ec;
 | 
				
			||||||
 | 
					    char fn[128];
 | 
				
			||||||
 | 
					    FILE *h_file = fopen(hfn, "w");
 | 
				
			||||||
 | 
					    char *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if(h_file == NULL)
 | 
				
			||||||
 | 
						return 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    snprintf(fn, sizeof(fn), "__%s__", hfn);
 | 
				
			||||||
 | 
					    for(p = fn; *p; p++)
 | 
				
			||||||
 | 
						if(!isalnum(*p))
 | 
				
			||||||
 | 
						    *p = '_';
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
    fprintf(h_file, "/* Generated from %s */\n", filename);
 | 
					    fprintf(h_file, "/* Generated from %s */\n", filename);
 | 
				
			||||||
    if(id_str) 
 | 
					    if(id_str) 
 | 
				
			||||||
	fprintf(h_file, "/* %s */\n", id_str);
 | 
						fprintf(h_file, "/* %s */\n", id_str);
 | 
				
			||||||
@@ -105,6 +156,26 @@ void prologue()
 | 
				
			|||||||
    fprintf(h_file, "typedef enum %s_error_number{\n", name);
 | 
					    fprintf(h_file, "typedef enum %s_error_number{\n", name);
 | 
				
			||||||
    fprintf(h_file, "\tERROR_TABLE_BASE_%s = %ld,\n", name, base);
 | 
					    fprintf(h_file, "\tERROR_TABLE_BASE_%s = %ld,\n", name, base);
 | 
				
			||||||
    fprintf(h_file, "\t%s_err_base = %ld,\n", name, base);
 | 
					    fprintf(h_file, "\t%s_err_base = %ld,\n", name, base);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    for(ec = codes; ec; ec = ec->next) {
 | 
				
			||||||
 | 
						fprintf(h_file, "\t%s = %ld,\n", ec->name, base + ec->number);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    fprintf(h_file, "\t%s_num_errors = %d\n", name, number);
 | 
				
			||||||
 | 
					    fprintf(h_file, "} %s_error_number;\n", name);
 | 
				
			||||||
 | 
					    fprintf(h_file, "\n");
 | 
				
			||||||
 | 
					    fprintf(h_file, "#endif /* %s */\n", fn);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    fclose(h_file);
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int
 | 
				
			||||||
 | 
					generate(void)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    if(generate_c() || generate_h())
 | 
				
			||||||
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int
 | 
					int
 | 
				
			||||||
@@ -131,42 +202,14 @@ main(int argc, char **argv)
 | 
				
			|||||||
    strncpy(Basename, p, sizeof(Basename));
 | 
					    strncpy(Basename, p, sizeof(Basename));
 | 
				
			||||||
    Basename[sizeof(Basename) - 1] = '\0';
 | 
					    Basename[sizeof(Basename) - 1] = '\0';
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    Basename[strcspn(Basename, "._")] = '\0';
 | 
					    Basename[strcspn(Basename, ".")] = '\0';
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    snprintf(hfn, sizeof(hfn), "%s_err.h", Basename);
 | 
					    snprintf(hfn, sizeof(hfn), "%s.h", Basename);
 | 
				
			||||||
    h_file = fopen(hfn, "w");
 | 
					    snprintf(cfn, sizeof(cfn), "%s.c", Basename);
 | 
				
			||||||
    snprintf(cfn, sizeof(cfn), "%s_err.c", Basename);
 | 
					 | 
				
			||||||
    c_file = fopen(cfn, "w");
 | 
					 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    yyparse();
 | 
					    yyparse();
 | 
				
			||||||
    
 | 
					 | 
				
			||||||
    fprintf(c_file, "\tNULL\n");
 | 
					 | 
				
			||||||
    fprintf(c_file, "};\n");
 | 
					 | 
				
			||||||
    fprintf(c_file, "\n");
 | 
					 | 
				
			||||||
    fprintf(c_file, 
 | 
					 | 
				
			||||||
	    "void initialize_%s_error_table_r(struct error_table **list)\n", 
 | 
					 | 
				
			||||||
	    name);
 | 
					 | 
				
			||||||
    fprintf(c_file, "{\n");
 | 
					 | 
				
			||||||
    fprintf(c_file, 
 | 
					 | 
				
			||||||
	    "    initialize_error_table_r(list, text, "
 | 
					 | 
				
			||||||
	    "%s_num_errors, ERROR_TABLE_BASE_%s);\n", name, name);
 | 
					 | 
				
			||||||
    fprintf(c_file, "}\n");
 | 
					 | 
				
			||||||
    fprintf(c_file, "\n");
 | 
					 | 
				
			||||||
    fprintf(c_file, "void initialize_%s_error_table(void)\n", name);
 | 
					 | 
				
			||||||
    fprintf(c_file, "{\n");
 | 
					 | 
				
			||||||
    fprintf(c_file,
 | 
					 | 
				
			||||||
	    "    init_error_table(text, ERROR_TABLE_BASE_%s, "
 | 
					 | 
				
			||||||
	    "%s_num_errors);\n", name, name);
 | 
					 | 
				
			||||||
    fprintf(c_file, "}\n");
 | 
					 | 
				
			||||||
    
 | 
					 | 
				
			||||||
    fprintf(h_file, "\t%s_num_errors = %d\n", name, number);
 | 
					 | 
				
			||||||
    fprintf(h_file, "} %s_error_number;\n", name);
 | 
					 | 
				
			||||||
    fprintf(h_file, "\n");
 | 
					 | 
				
			||||||
    fprintf(h_file, "#endif /* %s */\n", fn);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    fclose(h_file);
 | 
					 | 
				
			||||||
    fclose(c_file);
 | 
					 | 
				
			||||||
    if(numerror)
 | 
					    if(numerror)
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
    return 0;
 | 
					
 | 
				
			||||||
 | 
					    return generate();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user