# HG changeset patch # User etisserant # Date 1179215558 -7200 # Node ID 667721cf52c5674a3270062b7201d940b3b0e060 # Parent fd67f54e64e1e46700e402ad02c695e30a24aeac Now, stage4out can address files. Generate_cc have been split into one visitor per C file : pous, ressource and config. Work in progress. diff -r fd67f54e64e1 -r 667721cf52c5 stage4/generate_cc/generate_cc.cc --- a/stage4/generate_cc/generate_cc.cc Mon May 14 09:48:25 2007 +0200 +++ b/stage4/generate_cc/generate_cc.cc Tue May 15 09:52:38 2007 +0200 @@ -38,6 +38,7 @@ // #include /* required for NULL */ #include #include +#include #include #include "../../util/symtable.hh" @@ -300,12 +301,12 @@ /***********************************************************************/ -class generate_cc_c: public generate_cc_typedecl_c { +class generate_cc_pous_c: public generate_cc_typedecl_c { public: - generate_cc_c(stage4out_c *s4o_ptr) + generate_cc_pous_c(stage4out_c *s4o_ptr) : generate_cc_typedecl_c(s4o_ptr) {}; - virtual ~generate_cc_c(void) {} + virtual ~generate_cc_pous_c(void) {} public: @@ -767,16 +768,24 @@ return NULL; } - -/* intermediate helper symbol for program_declaration_c */ -/* { io_var_declarations | other_var_declarations } */ -/* - * NOTE: we re-use the var_declarations_list_c - */ - -/*********************************************/ -/* B.1.6 Sequential function chart elements */ -/*********************************************/ +}; /* generate_cc_pous_c */ + +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ + +class generate_cc_config_c: public generate_cc_typedecl_c { + + public: + generate_cc_config_c(stage4out_c *s4o_ptr) + : generate_cc_typedecl_c(s4o_ptr) {}; + virtual ~generate_cc_config_c(void) {} + /********************************/ /* B 1.7 Configuration elements */ @@ -884,93 +893,131 @@ s4o.indent_left(); s4o.print(s4o.indent_spaces + "}; /* class "); symbol->configuration_name->accept(*this); + s4o.print(" */\n\n\n"); return NULL; } - - - - - - - -#if 0 - -/* helper symbol for configuration_declaration */ -SYM_LIST(resource_declaration_list_c) - -/* -RESOURCE resource_name ON resource_type_name - optional_global_var_declarations - single_resource_declaration -END_RESOURCE -*/ -SYM_REF4(resource_declaration_c, resource_name, resource_type_name, global_var_declarations, resource_declaration) - -/* task_configuration_list program_configuration_list */ -SYM_REF2(single_resource_declaration_c, task_configuration_list, program_configuration_list) - -/* helper symbol for single_resource_declaration */ -SYM_LIST(task_configuration_list_c) - -/* helper symbol for single_resource_declaration */ -SYM_LIST(program_configuration_list_c) - -/* helper symbol for - * - access_path - * - instance_specific_init - */ -SYM_LIST(any_fb_name_list_c) - -/* [resource_name '.'] global_var_name ['.' structure_element_name] */ -SYM_REF4(global_var_reference_c, resource_name, global_var_name, structure_element_name, unused) - -/* prev_declared_program_name '.' symbolic_variable */ -SYM_REF2(program_output_reference_c, program_name, symbolic_variable) - -/* TASK task_name task_initialization */ -SYM_REF2(task_configuration_c, task_name, task_initialization) - -/* '(' [SINGLE ASSIGN data_source ','] [INTERVAL ASSIGN data_source ','] PRIORITY ASSIGN integer ')' */ -SYM_REF4(task_initialization_c, single_data_source, interval_data_source, priority_data_source, unused) - -/* PROGRAM [RETAIN | NON_RETAIN] program_name [WITH task_name] ':' program_type_name ['(' prog_conf_elements ')'] */ -SYM_REF6(program_configuration_c, retain_option, program_name, task_name, program_type_name, prog_conf_elements, unused) - -/* prog_conf_elements ',' prog_conf_element */ -SYM_LIST(prog_conf_elements_c) - -/* fb_name WITH task_name */ -SYM_REF2(fb_task_c, fb_name, task_name) - -/* any_symbolic_variable ASSIGN prog_data_source */ -SYM_REF2(prog_cnxn_assign_c, symbolic_variable, prog_data_source) - -/* any_symbolic_variable SENDTO data_sink */ -SYM_REF2(prog_cnxn_sendto_c, symbolic_variable, prog_data_source) - -/* VAR_CONFIG instance_specific_init_list END_VAR_BOGUS */ -SYM_REF2(instance_specific_initializations_c, instance_specific_init_list, unused) - -/* helper symbol for instance_specific_initializations */ -SYM_LIST(instance_specific_init_list_c) - -/* resource_name '.' program_name '.' {fb_name '.'} - ((variable_name [location] ':' located_var_spec_init) | (fb_name ':' fb_initialization)) -*/ -SYM_REF6(instance_specific_init_c, resource_name, program_name, any_fb_name_list, variable_name, location, initialization) - -/* helper symbol for instance_specific_init */ -/* function_block_type_name ':=' structure_initialization */ -SYM_REF2(fb_initialization_c, function_block_type_name, structure_initialization) - -#endif - - -}; /* generate_cc_c */ - - + +}; + +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ + + +class generate_cc_resources_c: public generate_cc_typedecl_c { + + public: + generate_cc_resources_c(stage4out_c *s4o_ptr) + : generate_cc_typedecl_c(s4o_ptr) {}; + virtual ~generate_cc_resources_c(void) {} + + void *visit(resource_declaration_c *symbol) { + return NULL; + } + + void *visit(single_resource_declaration_c *symbol) { + return NULL; + } + +}; +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ +/***********************************************************************/ + +class generate_cc_c: public iterator_visitor_c { + protected: + stage4out_c &s4o; + stage4out_c pous_s4o; + generate_cc_pous_c generate_cc_pous; + + const char *current_name; + + public: + generate_cc_c(stage4out_c *s4o_ptr): + s4o(*s4o_ptr), + generate_cc_pous(&pous_s4o) {} + + ~generate_cc_c(void) {} + +/*************************/ +/* B.1 - Common elements */ +/*************************/ +/*******************************************/ +/* B 1.1 - Letters, digits and identifiers */ +/*******************************************/ + void *visit(identifier_c *symbol) { + current_name = symbol->value; + return NULL; + } + +/**************************************/ +/* B.1.5 - Program organization units */ +/**************************************/ +/***********************/ +/* B 1.5.1 - Functions */ +/***********************/ + void *visit(function_declaration_c *symbol) { + symbol->accept(generate_cc_pous); + return NULL; + } + +/*****************************/ +/* B 1.5.2 - Function Blocks */ +/*****************************/ + void *visit(function_block_declaration_c *symbol) { + symbol->accept(generate_cc_pous); + return NULL; + } + +/**********************/ +/* B 1.5.3 - Programs */ +/**********************/ + void *visit(program_declaration_c *symbol) { + symbol->accept(generate_cc_pous); + return NULL; + } + + +/********************************/ +/* B 1.7 Configuration elements */ +/********************************/ + void *visit(configuration_declaration_c *symbol) { + symbol->configuration_name->accept(*this); + stage4out_c config_s4o(current_name, "c"); + generate_cc_config_c generate_cc_config(&config_s4o); + symbol->accept(generate_cc_config); + return NULL; + } + + void *visit(resource_declaration_c *symbol) { + symbol->resource_name->accept(*this); + stage4out_c resources_s4o(current_name, "c"); + generate_cc_resources_c generate_cc_resources(&resources_s4o); + symbol->accept(generate_cc_resources); + return NULL; + } + + void *visit(single_resource_declaration_c *symbol) { + stage4out_c resources_s4o("resource", "c"); + generate_cc_resources_c generate_cc_resources(&resources_s4o); + symbol->accept(generate_cc_resources); + return NULL; + } + + +}; /***********************************************************************/ /***********************************************************************/ diff -r fd67f54e64e1 -r 667721cf52c5 stage4/generate_iec/generate_iec.cc --- a/stage4/generate_iec/generate_iec.cc Mon May 14 09:48:25 2007 +0200 +++ b/stage4/generate_iec/generate_iec.cc Tue May 15 09:52:38 2007 +0200 @@ -42,6 +42,7 @@ // #include /* required for NULL */ #include #include +#include #include "generate_iec.hh" #include "../stage4.hh" diff -r fd67f54e64e1 -r 667721cf52c5 stage4/stage4.cc --- a/stage4/stage4.cc Mon May 14 09:48:25 2007 +0200 +++ b/stage4/stage4.cc Tue May 15 09:52:38 2007 +0200 @@ -36,8 +36,7 @@ // #include /* required for NULL */ #include #include - - +#include #include "stage4.hh" @@ -47,12 +46,31 @@ -stage4out_c::stage4out_c(std::string indent_level) { +stage4out_c::stage4out_c(std::string indent_level): + m_file(NULL) { + out = &std::cout; this->indent_level = indent_level; this->indent_spaces = ""; } -stage4out_c::~stage4out_c(void) {} +stage4out_c::stage4out_c(const char *radix, const char *extension, std::string indent_level) { + std::string filename(radix); + filename += "."; + filename += extension; + std::fstream *file = new std::fstream(filename.c_str(), std::fstream::out); + out = file; + m_file = file; + this->indent_level = indent_level; + this->indent_spaces = ""; +} + +stage4out_c::~stage4out_c(void) { + if(m_file) + { + m_file->close(); + delete m_file; + } +} void stage4out_c::indent_right(void) { @@ -68,29 +86,29 @@ void *stage4out_c::print(const char *str) { - std::cout << str; + *out << str; return NULL; } void *stage4out_c::printupper(const char *str) { for (int i = 0; str[i] != '\0'; i++) - std::cout << (unsigned char)toupper(str[i]); + *out << (unsigned char)toupper(str[i]); return NULL; } void *stage4out_c::printlocation(const char *str) { - std::cout << "__"; + *out << "__"; for (int i = 0; str[i] != '\0'; i++) if(str[i] == '.') - std::cout << '_'; + *out << '_'; else - std::cout << (unsigned char)toupper(str[i]); + *out << (unsigned char)toupper(str[i]); return NULL; } void *stage4out_c::print(std::string str) { - std::cout << str; + *out << str; return NULL; } @@ -102,7 +120,7 @@ #if 0 /* The C++ way of doint things... */ for (string::const_iterator p = str.begin(); p != str.end(); ++p) - std::cout << (unsigned char)toupper(*p); + *out << (unsigned char)toupper(*p); #else /* Or more simply... */ printupper(str.c_str()); @@ -110,7 +128,7 @@ return NULL; } void *stage4out_c::printlocation(std::string str) { - printlocation(str.c_str()); + return printlocation(str.c_str()); } diff -r fd67f54e64e1 -r 667721cf52c5 stage4/stage4.hh --- a/stage4/stage4.hh Mon May 14 09:48:25 2007 +0200 +++ b/stage4/stage4.hh Tue May 15 09:52:38 2007 +0200 @@ -31,7 +31,6 @@ #include "../absyntax/absyntax.hh" - class stage4out_c { public: std::string indent_level; @@ -39,6 +38,7 @@ public: stage4out_c(std::string indent_level = " "); + stage4out_c(const char *radix, const char *extension, std::string indent_level = " "); ~stage4out_c(void); void indent_right(void); @@ -53,6 +53,10 @@ void *printlocation(const char *str); void *printlocation(std::string str); + protected: + std::ostream *out; + std::fstream *m_file; + };