stage4/generate_c/generate_c_sfc.cc
author Mario de Sousa <msousa@fe.up.pt>
Wed, 01 Feb 2012 19:49:11 +0000
changeset 417 d48f53715f77
parent 392 9b88b8b6bccd
child 561 30a327be60d4
permissions -rwxr-xr-x
Re-write of stage3 code (done by Manuele and I), re-write of search_varfb_instance_type_c (done by myself), and several other bug fixes.
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     1
/*
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
     2
 *  matiec - a compiler for the programming languages defined in IEC 61131-3
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     3
 *
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
     4
 *  Copyright (C) 2003-2011  Mario de Sousa (msousa@fe.up.pt)
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
     5
 *  Copyright (C) 2007-2011  Laurent Bessard and Edouard Tisserant
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     6
 *
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
     7
 *  This program is free software: you can redistribute it and/or modify
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
     8
 *  it under the terms of the GNU General Public License as published by
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
     9
 *  the Free Software Foundation, either version 3 of the License, or
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    10
 *  (at your option) any later version.
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    11
 *
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    12
 *  This program is distributed in the hope that it will be useful,
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    13
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    14
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    15
 *  GNU General Public License for more details.
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    16
 *
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    17
 *  You should have received a copy of the GNU General Public License
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    18
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 244
diff changeset
    19
 *
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    23
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    24
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    25
typedef struct
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    26
{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    27
  transition_c *symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
  int priority;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
  int index;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    30
} TRANSITION;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    31
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    32
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    33
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    34
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    35
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    36
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    37
class generate_c_sfc_elements_c: public generate_c_base_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    38
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    39
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    40
    typedef enum {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    41
      transitionlist_sg,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    42
      transitiontest_sg,
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
    43
      transitiontestdebug_sg,
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    44
      stepset_sg,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    45
      stepreset_sg,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    46
      actionassociation_sg,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    47
      actionbody_sg
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    48
    } sfcgeneration_t;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    49
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    50
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    51
    generate_c_il_c *generate_c_il;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    52
    generate_c_st_c *generate_c_st;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    53
    generate_c_SFC_IL_ST_c *generate_c_code;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    54
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    55
    int transition_number;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    56
    std::list<TRANSITION> transition_list;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    57
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    58
    symbol_c *current_step;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    59
    symbol_c *current_action;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    60
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
    sfcgeneration_t wanted_sfcgeneration;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
  public:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
    64
    generate_c_sfc_elements_c(stage4out_c *s4o_ptr, symbol_c *name, symbol_c *scope, const char *variable_prefix = NULL)
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
    : generate_c_base_c(s4o_ptr) {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
    66
      generate_c_il = new generate_c_il_c(s4o_ptr, name, scope, variable_prefix);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
    67
      generate_c_st = new generate_c_st_c(s4o_ptr, name, scope, variable_prefix);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
    68
      generate_c_code = new generate_c_SFC_IL_ST_c(s4o_ptr, name, scope, variable_prefix);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
      this->set_variable_prefix(variable_prefix);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
    ~generate_c_sfc_elements_c(void) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
    73
      transition_list.clear();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
      delete generate_c_il;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
      delete generate_c_st;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
      delete generate_c_code;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    78
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    79
    void reset_transition_number(void) {transition_number = 0;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    80
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    81
    void generate(symbol_c *symbol, sfcgeneration_t generation_type) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    82
      wanted_sfcgeneration = generation_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
        case transitiontest_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
          {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    86
            std::list<TRANSITION>::iterator pt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
            for(pt = transition_list.begin(); pt != transition_list.end(); pt++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
              transition_number = pt->index;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    89
              pt->symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    90
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    93
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    94
          symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    95
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    96
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    97
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
    99
    void print_step_argument(symbol_c *step_name, const char* argument, bool setter=false) {
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   100
      print_variable_prefix();
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   101
      if (setter) s4o.print(",");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   102
      s4o.print("__step_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
      s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
      step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
      s4o.print("].");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
      s4o.print(argument);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   109
    void print_action_argument(symbol_c *action_name, const char* argument, bool setter=false) {
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   110
      print_variable_prefix();
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   111
      if (setter) s4o.print(",");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   112
      s4o.print("__action_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
      s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   114
      action_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
      s4o.print("].");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
      s4o.print(argument);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
    }      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
    void print_transition_number(void) {
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   120
      s4o.print_integer(transition_number);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   121
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   122
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   123
    void print_reset_step(symbol_c *step_name) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   124
      s4o.print(s4o.indent_spaces);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   125
      s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   126
      s4o.print("(");
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   127
      print_step_argument(step_name, "state", true);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   128
      s4o.print(",0);\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
    void print_set_step(symbol_c *step_name) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
      s4o.print(s4o.indent_spaces);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   133
      s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   134
      s4o.print("(");
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   135
      print_step_argument(step_name, "state", true);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   136
      s4o.print(",1);\n" + s4o.indent_spaces);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
      print_step_argument(step_name, "elapsed_time");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   138
      s4o.print(" = __time_to_timespec(1, 0, 0, 0, 0, 0);\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
/* B.1.6  Sequential function chart elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   143
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
    void *visit(initial_step_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   146
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   147
        case actionassociation_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
          if (((list_c*)symbol->action_association_list)->n > 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
            s4o.print(s4o.indent_spaces + "// ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   150
            symbol->step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   151
            s4o.print(" action associations\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   152
            current_step = symbol->step_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   153
            s4o.print(s4o.indent_spaces + "{\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   154
            s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
            s4o.print(s4o.indent_spaces + "char activated = ");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   156
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   157
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   158
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   159
            s4o.print(") && !");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   160
            print_step_argument(current_step, "prev_state");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   161
            s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
            s4o.print(s4o.indent_spaces + "char desactivated = !");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   163
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   164
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   165
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   166
            s4o.print(") && ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   167
            print_step_argument(current_step, "prev_state");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   168
            s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   169
            s4o.print(s4o.indent_spaces + "char active = ");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   170
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   171
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   173
            s4o.print(");\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
            symbol->action_association_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   175
            s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   176
            s4o.print(s4o.indent_spaces + "}\n\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   177
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   178
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   179
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
    void *visit(step_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   187
        case actionassociation_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   188
          if (((list_c*)symbol->action_association_list)->n > 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
            s4o.print(s4o.indent_spaces + "// ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
            symbol->step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
            s4o.print(" action associations\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
            current_step = symbol->step_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
            s4o.print(s4o.indent_spaces + "{\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
            s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
            s4o.print(s4o.indent_spaces + "char activated = ");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   196
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   197
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   199
            s4o.print(") && !");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
            print_step_argument(current_step, "prev_state");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
            s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   202
            s4o.print(s4o.indent_spaces + "char desactivated = !");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   203
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   204
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   205
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   206
            s4o.print(") && ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   207
            print_step_argument(current_step, "prev_state");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
            s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
            s4o.print(s4o.indent_spaces + "char active = ");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   210
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   211
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   212
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   213
            s4o.print(");\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
            symbol->action_association_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
            s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
            s4o.print(s4o.indent_spaces + "}\n\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   218
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
    void *visit(transition_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   226
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   227
        case transitionlist_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   228
          {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   229
            TRANSITION *transition;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   230
            transition = new TRANSITION;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   231
            transition->symbol = symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   232
            transition->index = transition_number;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   233
            if (symbol->integer != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   234
              transition->priority = atoi(((token_c *)symbol->integer)->value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   235
              std::list<TRANSITION>::iterator pt = transition_list.begin();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   236
              while (pt != transition_list.end() && pt->priority <= transition->priority) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   237
                pt++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   238
              } 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   239
              transition_list.insert(pt, *transition);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   240
            } 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   241
            else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   242
              transition->priority = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   243
              transition_list.push_back(*transition);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   244
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   245
            transition_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   246
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   247
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   248
        case transitiontest_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   249
          s4o.print(s4o.indent_spaces + "if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   250
          symbol->from_steps->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   251
          s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   252
          s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   253
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   254
          // Calculate transition value
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   255
          symbol->transition_condition->accept(*this);
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   256
          
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   257
          if (symbol->integer != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   258
            s4o.print(s4o.indent_spaces + "if (");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   259
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   260
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
            print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   262
            s4o.print("__transition_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
            print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   264
            s4o.print("])) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
            s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
            wanted_sfcgeneration = stepreset_sg;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
            symbol->from_steps->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
            wanted_sfcgeneration = transitiontest_sg;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
            s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
            s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   271
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   272
          s4o.indent_left();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   273
          s4o.print(s4o.indent_spaces + "}\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   274
          s4o.print(s4o.indent_spaces + "else {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   275
          s4o.indent_right();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   276
          // Calculate transition value for debug
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   277
          s4o.print(s4o.indent_spaces + "if (__DEBUG) {\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   278
          s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   279
          wanted_sfcgeneration = transitiontestdebug_sg;
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   280
          symbol->transition_condition->accept(*this);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   281
          wanted_sfcgeneration = transitiontest_sg;
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   282
          s4o.indent_left();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   283
          s4o.print(s4o.indent_spaces + "}\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   284
          s4o.print(s4o.indent_spaces);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   285
          s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   286
          s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
          print_variable_prefix();
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   288
          s4o.print(",__transition_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
          print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   290
          s4o.print("],0);\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
          s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
          s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   293
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   294
        case stepset_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
          s4o.print(s4o.indent_spaces + "if (");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   296
          s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   297
          s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   299
          s4o.print("__transition_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
          print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   301
          s4o.print("])) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
          s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
          symbol->to_steps->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
          s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
          s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
          transition_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   307
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   308
        case stepreset_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   309
          if (symbol->integer == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   310
            s4o.print(s4o.indent_spaces + "if (");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   311
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   312
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313
            print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   314
            s4o.print("__transition_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   315
            print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   316
            s4o.print("])) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   317
            s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   318
            symbol->from_steps->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
            s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   320
            s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   321
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   322
          transition_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   323
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   324
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   325
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   326
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   327
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   328
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   329
    
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   330
    void *visit(transition_condition_c *symbol) {
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   331
      switch (wanted_sfcgeneration) {
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   332
        case transitiontest_sg:
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   333
        case transitiontestdebug_sg:
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   334
          // Transition condition is in IL
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   335
          if (symbol->transition_condition_il != NULL) {
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   336
            generate_c_il->declare_backup_variable();
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   337
            s4o.print(s4o.indent_spaces);
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   338
            symbol->transition_condition_il->accept(*generate_c_il);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   339
            s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   340
            s4o.print("(");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   341
            print_variable_prefix();
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   342
            s4o.print(",");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   343
            if (wanted_sfcgeneration == transitiontestdebug_sg)
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   344
              s4o.print("__debug_");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   345
            else
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   346
              s4o.print("__");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   347
            s4o.print("transition_list[");
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   348
            print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   349
            s4o.print("],");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   350
            generate_c_il->print_backup_variable();
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   351
            generate_c_il->reset_default_variable_name();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   352
            s4o.print(");\n");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   353
          }
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   354
          // Transition condition is in ST
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   355
          if (symbol->transition_condition_st != NULL) {
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   356
            s4o.print(s4o.indent_spaces);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   357
            s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   358
            s4o.print("(");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   359
            print_variable_prefix();
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   360
            s4o.print(",");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   361
            if (wanted_sfcgeneration == transitiontestdebug_sg)
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   362
              s4o.print("__debug_");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   363
            else
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   364
              s4o.print("__");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   365
            s4o.print("transition_list[");
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   366
            print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   367
            s4o.print("],");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   368
            symbol->transition_condition_st->accept(*generate_c_st);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   369
            s4o.print(");\n");
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   370
          }
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   371
          if (wanted_sfcgeneration == transitiontest_sg) {
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   372
            s4o.print(s4o.indent_spaces + "if (__DEBUG) {\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   373
            s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   374
            s4o.print(s4o.indent_spaces);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   375
            s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   376
            s4o.print("(");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   377
            print_variable_prefix();
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   378
            s4o.print(",__debug_transition_list[");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   379
            print_transition_number();
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   380
            s4o.print("],");
221
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 217
diff changeset
   381
            s4o.print(GET_VAR);
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 217
diff changeset
   382
            s4o.print("(");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   383
            print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   384
            s4o.print("__transition_list[");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   385
            print_transition_number();
221
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 217
diff changeset
   386
            s4o.print("]));\n");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   387
            s4o.indent_left();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   388
            s4o.print(s4o.indent_spaces + "}\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   389
          }
87
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   390
          break;
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   391
        default:
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   392
          break;
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   393
      }
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   394
      return NULL;
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   395
    }
b97f9ad7b2c6 Bug on SFC transition parsing and generation fixed
lbessard
parents: 70
diff changeset
   396
    
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   397
    void *visit(action_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   399
        case actionbody_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   400
          s4o.print(s4o.indent_spaces + "if(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   401
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   402
          s4o.print("__action_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   403
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
          symbol->action_name->accept(*this);
121
9e8ce092e169 Adding support for POU struct definition in POUS.h
lbessard
parents: 120
diff changeset
   405
          s4o.print("].state) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
          s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
          // generate action code
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
          symbol->function_block_body->accept(*generate_c_code);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   410
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   411
          s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   412
          s4o.print(s4o.indent_spaces + "}\n\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   414
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   415
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
    void *visit(steps_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
      if (symbol->step_name != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
        switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
          case transitiontest_sg:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   424
        	s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   425
        	s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   426
            print_step_argument(symbol->step_name, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   427
            s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   428
            break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   429
          case stepset_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
            print_set_step(symbol->step_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
            break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
          case stepreset_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
            print_reset_step(symbol->step_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   434
            break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   435
          default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   436
            break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   437
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   439
      else if (symbol->step_name_list != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   440
        symbol->step_name_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   441
      }  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   442
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   443
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   444
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   445
    void *visit(step_name_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   446
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   447
        case transitiontest_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   448
          for(int i = 0; i < symbol->n; i++) {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   449
        	s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   450
        	s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
            print_step_argument(symbol->elements[i], "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   452
            s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
            if (i < symbol->n - 1) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   454
              s4o.print(" && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   455
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   456
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   457
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   458
        case stepset_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   459
          for(int i = 0; i < symbol->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   460
            print_set_step(symbol->elements[i]);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   461
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   462
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   463
        case stepreset_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   464
          for(int i = 0; i < symbol->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
            print_reset_step(symbol->elements[i]);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   467
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   468
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   469
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   470
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   471
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   472
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   473
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   474
    void *visit(action_association_list_c* symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   475
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   476
        case actionassociation_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   477
          print_list(symbol, "", "\n", "\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   478
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   479
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   480
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   484
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   485
    void *visit(action_association_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   486
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
        case actionassociation_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   488
          if (symbol->action_qualifier != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   489
            current_action = symbol->action_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   490
            symbol->action_qualifier->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   491
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
          else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
            s4o.print(s4o.indent_spaces + "if (");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   494
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   495
            s4o.print("(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
            print_step_argument(current_step, "state");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   497
            s4o.print(")) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
            s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
            s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   500
            print_action_argument(symbol->action_name, "state");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
            s4o.print(" = 1;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
            s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   503
            s4o.print(s4o.indent_spaces + "}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   505
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   506
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   507
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   508
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   509
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   510
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   511
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   512
    void *visit(action_qualifier_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   513
      switch (wanted_sfcgeneration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   514
        case actionassociation_sg:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   515
          {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   516
            char *qualifier = (char *)symbol->action_qualifier->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   517
            s4o.print(s4o.indent_spaces + "if (");
155
e094c92cf197 set and reset action fixed
greg
parents: 149
diff changeset
   518
            if (strcmp(qualifier, "N") == 0 || strcmp(qualifier, "S") == 0 ||
e094c92cf197 set and reset action fixed
greg
parents: 149
diff changeset
   519
                strcmp(qualifier, "R") == 0) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   520
              s4o.print("active");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   521
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   522
            if (strcmp(qualifier, "P") == 0 || strcmp(qualifier, "SD") == 0 || 
155
e094c92cf197 set and reset action fixed
greg
parents: 149
diff changeset
   523
                strcmp(qualifier, "DS") == 0 || strcmp(qualifier, "SL") == 0) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   524
              s4o.print("activated");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   525
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
            if (strcmp(qualifier, "D") == 0 || strcmp(qualifier, "L") == 0) {
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   527
              s4o.print("active && __time_cmp(");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   528
              print_step_argument(current_step, "elapsed_time");
120
74640e3c7f53 Bug with D and L action qualifier and timing management in SFC generated fixed
lbessard
parents: 119
diff changeset
   529
              s4o.print(", ");
74640e3c7f53 Bug with D and L action qualifier and timing management in SFC generated fixed
lbessard
parents: 119
diff changeset
   530
              symbol->action_time->accept(*this);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   531
              if (strcmp(qualifier, "D") == 0) {
120
74640e3c7f53 Bug with D and L action qualifier and timing management in SFC generated fixed
lbessard
parents: 119
diff changeset
   532
                s4o.print(") >= 0");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   533
              }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   534
              else {
120
74640e3c7f53 Bug with D and L action qualifier and timing management in SFC generated fixed
lbessard
parents: 119
diff changeset
   535
                s4o.print(") < 0");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   536
              }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   537
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   538
            s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   539
            s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   540
            s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   541
            if (strcmp(qualifier, "N") == 0 || strcmp(qualifier, "P") == 0 ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   542
                strcmp(qualifier, "D") == 0 || strcmp(qualifier, "L") == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   543
              print_action_argument(current_action, "state");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   544
              s4o.print(" = 1;\n");  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   545
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   546
            if (strcmp(qualifier, "S") == 0) {
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   547
              print_action_argument(current_action, "set");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   548
              s4o.print(" = 1;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   549
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   550
            if (strcmp(qualifier, "R") == 0) {
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   551
              print_action_argument(current_action, "reset");
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   552
              s4o.print(" = 1;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   553
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   554
            if (strcmp(qualifier, "SD") == 0 || strcmp(qualifier, "DS") == 0 || 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   555
                strcmp(qualifier, "SL") == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   556
              if (strcmp(qualifier, "SL") == 0) {
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   557
                print_action_argument(current_action, "reset_remaining_time");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   558
              }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   559
              else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   560
                print_action_argument(current_action, "set_remaining_time");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   561
              }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   562
              s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   563
              symbol->action_time->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   564
              s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   565
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   566
            s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   567
            s4o.print(s4o.indent_spaces + "}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   568
            if (strcmp(qualifier, "DS") == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   569
              s4o.print("desactivated");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   570
              s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   571
              s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   572
              print_action_argument(current_action, "set_remaining_time");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   573
              s4o.print(" = __time_to_timespec(1, 0, 0, 0, 0, 0);\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   574
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   575
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   576
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   577
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   578
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   579
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   580
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   581
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   582
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   583
    void *visit(qualifier_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   584
      return (void *)symbol->value;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   585
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   586
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   587
    void *visit(timed_qualifier_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   588
      return (void *)symbol->value;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   589
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   590
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   591
}; /* generate_c_sfc_actiondecl_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   592
 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   593
 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   594
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   595
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   596
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   597
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   598
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   599
class generate_c_sfc_c: public generate_c_typedecl_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   600
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   601
  private:
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   602
    std::list<VARIABLE> variable_list;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   603
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   604
    generate_c_sfc_elements_c *generate_c_sfc_elements;
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   605
    search_var_instance_decl_c *search_var_instance_decl;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   606
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   607
  public:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   608
    generate_c_sfc_c(stage4out_c *s4o_ptr, symbol_c *name, symbol_c *scope, const char *variable_prefix = NULL)
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   609
    : generate_c_typedecl_c(s4o_ptr) {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   610
      generate_c_sfc_elements = new generate_c_sfc_elements_c(s4o_ptr, name, scope, variable_prefix);
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   611
      search_var_instance_decl = new search_var_instance_decl_c(scope);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   612
      this->set_variable_prefix(variable_prefix);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   613
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   614
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   615
    virtual ~generate_c_sfc_c(void) {
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   616
      variable_list.clear();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   617
      delete generate_c_sfc_elements;
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   618
      delete search_var_instance_decl;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   619
    }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   620
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   621
    bool is_variable(symbol_c *symbol) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   622
      /* we try to find the variable instance declaration, to determine if symbol is variable... */
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   623
      symbol_c *var_decl = search_var_instance_decl->get_decl(symbol);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   624
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   625
      return var_decl != NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   626
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   627
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   628
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   629
/* B.1.6  Sequential function chart elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   630
/*********************************************/
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   631
    
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   632
    void *visit(sequential_function_chart_c *symbol) {
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   633
      int i;
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   634
      
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   635
      generate_c_sfc_elements->reset_transition_number();
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   636
      for(i = 0; i < symbol->n; i++) {
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   637
        symbol->elements[i]->accept(*this);
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   638
        generate_c_sfc_elements->generate(symbol->elements[i], generate_c_sfc_elements_c::transitionlist_sg);
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   639
      }
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   640
      
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   641
      s4o.print(s4o.indent_spaces +"INT i;\n");
125
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 121
diff changeset
   642
      s4o.print(s4o.indent_spaces +"BOOL transition;\n");
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 121
diff changeset
   643
      s4o.print(s4o.indent_spaces +"TIME elapsed_time, current_time;\n\n");
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 121
diff changeset
   644
      
229
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   645
      /* generate elapsed_time initializations */
125
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 121
diff changeset
   646
      s4o.print(s4o.indent_spaces + "// Calculate elapsed_time\n");
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 121
diff changeset
   647
      s4o.print(s4o.indent_spaces +"current_time = __CURRENT_TIME;\n");
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   648
//       s4o.print(s4o.indent_spaces +"elapsed_time = __time_sub(__BOOL_LITERAL(TRUE), NULL, current_time, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   649
//       s4o.print(s4o.indent_spaces +"elapsed_time = SUB_TIME(__BOOL_LITERAL(TRUE), NULL, current_time, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   650
      s4o.print(s4o.indent_spaces +"elapsed_time = __time_sub(current_time, ");
125
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 121
diff changeset
   651
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   652
      s4o.print("__lasttick_time);\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   653
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   654
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   655
      s4o.print("__lasttick_time = current_time;\n");
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   656
      
229
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   657
      /* generate transition initializations */
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   658
      s4o.print(s4o.indent_spaces + "// Transitions initialization\n");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   659
      s4o.print(s4o.indent_spaces + "if (__DEBUG) {\n");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   660
      s4o.indent_right();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   661
      s4o.print(s4o.indent_spaces + "for (i = 0; i < ");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   662
      print_variable_prefix();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   663
      s4o.print("__nb_transitions; i++) {\n");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   664
      s4o.indent_right();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   665
      s4o.print(s4o.indent_spaces);
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   666
      print_variable_prefix();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   667
      s4o.print("__transition_list[i] = ");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   668
      print_variable_prefix();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   669
      s4o.print("__debug_transition_list[i];\n");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   670
      s4o.indent_left();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   671
      s4o.print(s4o.indent_spaces + "}\n");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   672
      s4o.indent_left();
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   673
      s4o.print(s4o.indent_spaces + "}\n");
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   674
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   675
      /* generate step initializations */
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   676
      s4o.print(s4o.indent_spaces + "// Steps initialization\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   677
      s4o.print(s4o.indent_spaces + "for (i = 0; i < ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   678
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   679
      s4o.print("__nb_steps; i++) {\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   680
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   681
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   682
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   683
      s4o.print("__step_list[i].prev_state = ");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   684
      s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   685
      s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   686
      print_variable_prefix();
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   687
      s4o.print("__step_list[i].state);\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   688
      s4o.print(s4o.indent_spaces + "if (");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   689
      s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   690
      s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   691
      print_variable_prefix();
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 155
diff changeset
   692
      s4o.print("__step_list[i].state)) {\n");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   693
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   694
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   695
      print_variable_prefix();
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   696
//      s4o.print("__step_list[i].elapsed_time = __time_add(__BOOL_LITERAL(TRUE), NULL, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   697
//      s4o.print("__step_list[i].elapsed_time = ADD_TIME(__BOOL_LITERAL(TRUE), NULL, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   698
      s4o.print("__step_list[i].elapsed_time = __time_add(");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   699
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   700
      s4o.print("__step_list[i].elapsed_time, elapsed_time);\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   701
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   702
      s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   703
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   704
      s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   705
229
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   706
      /* generate action initializations */
ca7bc1324540 Bug on SFC debugging fixed
laurent
parents: 221
diff changeset
   707
      s4o.print(s4o.indent_spaces + "// Actions initialization\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   708
      s4o.print(s4o.indent_spaces + "for (i = 0; i < ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   709
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   710
      s4o.print("__nb_actions; i++) {\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   711
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   712
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   713
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   714
      s4o.print("__action_list[i].state = 0;\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   715
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   716
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   717
      s4o.print("__action_list[i].set = 0;\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   718
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   719
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   720
      s4o.print("__action_list[i].reset = 0;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   721
      s4o.print(s4o.indent_spaces + "if (");
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   722
      s4o.print("__time_cmp(");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   723
      print_variable_prefix();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   724
      s4o.print("__action_list[i].set_remaining_time, __time_to_timespec(1, 0, 0, 0, 0, 0)) > 0) {\n");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   725
      s4o.indent_right();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   726
      s4o.print(s4o.indent_spaces);
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   727
      print_variable_prefix();
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   728
//       s4o.print("__action_list[i].set_remaining_time = __time_sub(__BOOL_LITERAL(TRUE), NULL, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   729
//       s4o.print("__action_list[i].set_remaining_time = SUB_TIME(__BOOL_LITERAL(TRUE), NULL, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   730
      s4o.print("__action_list[i].set_remaining_time = __time_sub(");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   731
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   732
      s4o.print("__action_list[i].set_remaining_time, elapsed_time);\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   733
      s4o.print(s4o.indent_spaces + "if (");
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   734
      s4o.print("__time_cmp(");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   735
      print_variable_prefix();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   736
      s4o.print("__action_list[i].set_remaining_time, __time_to_timespec(1, 0, 0, 0, 0, 0)) <= 0) {\n");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   737
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   738
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   739
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   740
      s4o.print("__action_list[i].set_remaining_time = __time_to_timespec(1, 0, 0, 0, 0, 0);\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   741
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   742
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   743
      s4o.print("__action_list[i].set = 1;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   744
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   745
      s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   746
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   747
      s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   748
      s4o.print(s4o.indent_spaces + "if (");
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   749
      s4o.print("__time_cmp(");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   750
      print_variable_prefix();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   751
      s4o.print("__action_list[i].reset_remaining_time, __time_to_timespec(1, 0, 0, 0, 0, 0)) > 0) {\n");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   752
      s4o.indent_right();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   753
      s4o.print(s4o.indent_spaces);
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   754
      print_variable_prefix();
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   755
//       s4o.print("__action_list[i].reset_remaining_time = __time_sub(__BOOL_LITERAL(TRUE), NULL, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   756
//       s4o.print("__action_list[i].reset_remaining_time = SUB_TIME(__BOOL_LITERAL(TRUE), NULL, ");
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   757
      s4o.print("__action_list[i].reset_remaining_time = __time_sub(");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   758
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   759
      s4o.print("__action_list[i].reset_remaining_time, elapsed_time);\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   760
      s4o.print(s4o.indent_spaces + "if (");
350
2c3c4dc34979 Support for semantic verification of calls to standard functions.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   761
      s4o.print("__time_cmp(");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   762
      print_variable_prefix();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 141
diff changeset
   763
      s4o.print("__action_list[i].reset_remaining_time, __time_to_timespec(1, 0, 0, 0, 0, 0)) <= 0) {\n");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   764
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   765
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   766
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   767
      s4o.print("__action_list[i].reset_remaining_time = __time_to_timespec(1, 0, 0, 0, 0, 0);\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   768
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   769
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   770
      s4o.print("__action_list[i].reset = 1;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   771
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   772
      s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   773
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   774
      s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   775
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   776
      s4o.print(s4o.indent_spaces + "}\n\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   777
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   778
      /* generate transition tests */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   779
      s4o.print(s4o.indent_spaces + "// Transitions fire test\n");
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   780
      generate_c_sfc_elements->generate((symbol_c *)symbol, generate_c_sfc_elements_c::transitiontest_sg);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   781
      s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   782
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   783
      /* generate transition reset steps */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   784
      s4o.print(s4o.indent_spaces + "// Transitions reset steps\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   785
      generate_c_sfc_elements->reset_transition_number();
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   786
      for(i = 0; i < symbol->n; i++) {
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   787
        generate_c_sfc_elements->generate(symbol->elements[i], generate_c_sfc_elements_c::stepreset_sg);
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   788
      }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   789
      s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   790
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   791
      /* generate transition set steps */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   792
      s4o.print(s4o.indent_spaces + "// Transitions set steps\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   793
      generate_c_sfc_elements->reset_transition_number();
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   794
      for(i = 0; i < symbol->n; i++) {
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   795
        generate_c_sfc_elements->generate(symbol->elements[i], generate_c_sfc_elements_c::stepset_sg);
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   796
      }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   797
      s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   798
      
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   799
      /* generate step association */
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   800
      s4o.print(s4o.indent_spaces + "// Steps association\n");
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   801
      for(i = 0; i < symbol->n; i++) {
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   802
        generate_c_sfc_elements->generate(symbol->elements[i], generate_c_sfc_elements_c::actionassociation_sg);
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   803
      }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   804
      s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   805
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   806
      /* generate action state evaluation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   807
      s4o.print(s4o.indent_spaces + "// Actions state evaluation\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   808
      s4o.print(s4o.indent_spaces + "for (i = 0; i < ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   809
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   810
      s4o.print("__nb_actions; i++) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   811
      s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   812
      s4o.print(s4o.indent_spaces + "if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   813
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   814
      s4o.print("__action_list[i].set) {\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   815
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   816
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   817
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   818
      s4o.print("__action_list[i].stored = 1;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   819
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   820
      s4o.print(s4o.indent_spaces + "}\n" + s4o.indent_spaces + "if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   821
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   822
      s4o.print("__action_list[i].reset) {\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   823
      s4o.indent_right();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   824
      s4o.print(s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   825
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   826
      s4o.print("__action_list[i].set_remaining_time = __time_to_timespec(1, 0, 0, 0, 0, 0);\n" + s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   827
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   828
      s4o.print("__action_list[i].reset_remaining_time = __time_to_timespec(1, 0, 0, 0, 0, 0);\n" + s4o.indent_spaces);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   829
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   830
      s4o.print("__action_list[i].stored = 0;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   831
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   832
      s4o.print(s4o.indent_spaces + "}\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   833
      print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   834
      s4o.print("__action_list[i].state |= ");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   835
      print_variable_prefix();
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   836
      s4o.print("__action_list[i].stored;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   837
      s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   838
      s4o.print(s4o.indent_spaces + "}\n\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   839
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   840
      /* generate action execution */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   841
      s4o.print(s4o.indent_spaces + "// Actions execution\n");
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   842
      {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   843
        std::list<VARIABLE>::iterator pt;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   844
        for(pt = variable_list.begin(); pt != variable_list.end(); pt++) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   845
          symbol_c *var_decl = search_var_instance_decl->get_decl(pt->symbol);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   846
          if (var_decl != NULL) {
417
d48f53715f77 Re-write of stage3 code (done by Manuele and I), re-write of search_varfb_instance_type_c (done by myself), and several other bug fixes.
Mario de Sousa <msousa@fe.up.pt>
parents: 392
diff changeset
   847
            unsigned int vartype = search_var_instance_decl->get_vartype(pt->symbol);
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   848
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   849
            s4o.print(s4o.indent_spaces);
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   850
            if (vartype == search_var_instance_decl_c::external_vt)
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   851
          	  s4o.print(SET_EXTERNAL);
392
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   852
          	else if (vartype == search_var_instance_decl_c::located_vt)
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   853
          	  s4o.print(SET_LOCATED);
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   854
          	else
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   855
          	  s4o.print(SET_VAR);
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   856
            s4o.print("(");
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   857
          	print_variable_prefix();
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   858
          	s4o.print(",");
9b88b8b6bccd Fixing generated code for global variables. Adding support for defining global variables with complex type
laurent
parents: 350
diff changeset
   859
          	pt->symbol->accept(*this);
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   860
            s4o.print(",");
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   861
            print_variable_prefix();
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   862
            s4o.print("__action_list[");
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   863
            s4o.print(SFC_STEP_ACTION_PREFIX);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   864
            pt->symbol->accept(*this);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   865
            s4o.print("].state);\n");
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   866
          }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   867
        }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   868
      }
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   869
      for(i = 0; i < symbol->n; i++) {
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   870
        generate_c_sfc_elements->generate(symbol->elements[i], generate_c_sfc_elements_c::actionbody_sg);
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   871
      }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   872
      s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   873
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   874
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   875
    }
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 111
diff changeset
   876
    
244
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   877
    void *visit(initial_step_c *symbol) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   878
      symbol->action_association_list->accept(*this);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   879
      return NULL;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   880
    }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   881
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   882
    void *visit(step_c *symbol) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   883
      symbol->action_association_list->accept(*this);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   884
      return NULL;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   885
    }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   886
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   887
    void *visit(action_association_c *symbol) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   888
      symbol_c *var_decl = search_var_instance_decl->get_decl(symbol->action_name);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   889
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   890
      if (var_decl != NULL) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   891
        std::list<VARIABLE>::iterator pt;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   892
        for(pt = variable_list.begin(); pt != variable_list.end(); pt++) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   893
          if (!compare_identifiers(pt->symbol, symbol->action_name))
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   894
            return NULL;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   895
        }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   896
        VARIABLE *variable;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   897
        variable = new VARIABLE;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   898
        variable->symbol = (identifier_c*)(symbol->action_name);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   899
        variable_list.push_back(*variable);
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   900
      }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   901
      return NULL;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   902
    }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   903
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   904
    void *visit(transition_c *symbol) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   905
      return NULL;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   906
    }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   907
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   908
    void *visit(action_c *symbol) {
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   909
      return NULL;
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   910
    }
3a478229db8b Adding support for generating code for variable in step action association instead of action
laurent
parents: 229
diff changeset
   911
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   912
    void generate(sequential_function_chart_c *sfc) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   913
      sfc->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   914
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   915
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   916
}; /* generate_c_sfc_c */