stage4/generate_c/generate_c_sfcdecl.cc
author Mario de Sousa <msousa@fe.up.pt>
Wed, 30 Mar 2011 19:53:32 +0100
changeset 257 90782e241346
parent 160 59d58f5e6caa
child 221 c6aed7e5f070
permissions -rwxr-xr-x
Huge change.
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     1
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     2
 * (c) 2007 Mario de Sousa, Laurent Bessard
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     3
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     4
 * Offered to the public under the terms of the GNU General Public License
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     5
 * as published by the Free Software Foundation; either version 2 of the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     6
 * License, or (at your option) any later version.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     7
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     8
 * This program is distributed in the hope that it will be useful, but
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     9
 * WITHOUT ANY WARRANTY; without even the implied warranty of
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    10
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    11
 * Public License for more details.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    12
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    13
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    14
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    15
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    16
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    17
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    18
 * An IEC 61131-3 IL and ST compiler.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    19
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 * Based on the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * FINAL DRAFT - IEC 61131-3, 2nd Ed. (2001-12-10)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 *
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    26
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    27
 * Conversion of sfc networks (i.e. SFC code).
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
 * This is part of the 4th stage that generates
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    30
 * a c++ source program equivalent to the SFC, IL and ST
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    31
 * code.
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
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    38
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    39
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    40
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    41
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    42
class generate_c_sfcdecl_c: protected generate_c_typedecl_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    43
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    44
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    45
      typedef enum {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    46
        sfcdecl_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    47
        sfcinit_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    48
        stepcount_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    49
        stepdef_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    50
        stepundef_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    51
        actiondef_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    52
        actionundef_sd,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    53
        actioncount_sd
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    54
       } sfcdeclaration_t;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    55
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    56
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    57
    char step_number;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    58
    char action_number;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    59
    char transition_number;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    60
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
    sfcdeclaration_t wanted_sfcdeclaration;
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:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
    generate_c_sfcdecl_c(stage4out_c *s4o_ptr, sfcdeclaration_t sfcdeclaration)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
    : generate_c_typedecl_c(s4o_ptr) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
      wanted_sfcdeclaration = sfcdeclaration;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
    ~generate_c_sfcdecl_c(void) {}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
    void print(symbol_c *symbol, const char *variable_prefix = NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
      this->set_variable_prefix(variable_prefix);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
      symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
/* B.1.6  Sequential function chart elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    78
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    79
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    80
    void *visit(sequential_function_chart_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    81
      step_number = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    82
      action_number = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
      transition_number = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
      switch (wanted_sfcdeclaration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
        case sfcdecl_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    86
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    89
          /* steps table declaration */
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
    90
          s4o.print(s4o.indent_spaces + "STEP __step_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
          s4o.print_integer(step_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
          s4o.print("];\n");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
    93
          s4o.print(s4o.indent_spaces + "UINT __nb_steps;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    94
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    95
          /* actions table declaration */
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
    96
          s4o.print(s4o.indent_spaces + "ACTION __action_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    97
          s4o.print_integer(action_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
          s4o.print("];\n");
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
    99
          s4o.print(s4o.indent_spaces + "UINT __nb_actions;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   100
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   101
          /* transitions table declaration */
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   102
          s4o.print(s4o.indent_spaces + "BOOL __transition_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
          s4o.print_integer(transition_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
          s4o.print("];\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
          
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   106
          /* transitions debug table declaration */
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   107
          s4o.print(s4o.indent_spaces + "BOOL __debug_transition_list[");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   108
          s4o.print_integer(transition_number);
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   109
          s4o.print("];\n");
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   110
          
125
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 120
diff changeset
   111
          /* last_ticktime declaration */
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   112
          s4o.print(s4o.indent_spaces + "TIME __lasttick_time;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   114
        case sfcinit_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
          s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
          s4o.print("UINT i;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
          /* steps table count */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
          wanted_sfcdeclaration = stepcount_sd;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   120
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   121
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   122
          s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   123
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   124
          s4o.print("__nb_steps = ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   125
          s4o.print_integer(step_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   126
          s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
          step_number = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   128
          wanted_sfcdeclaration = sfcinit_sd;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
          /* steps table initialisation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
          s4o.print(s4o.indent_spaces + "STEP temp_step = {0, 0, 0};\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
          s4o.print(s4o.indent_spaces + "for(i = 0; i < ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   133
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   134
          s4o.print("__nb_steps; i++) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   135
          s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   136
          s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   138
          s4o.print("__step_list[i] = temp_step;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
          s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
          s4o.print(s4o.indent_spaces + "}\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   143
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
          /* steps table count */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
          wanted_sfcdeclaration = actioncount_sd;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   146
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   147
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
          s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   150
          s4o.print("__nb_actions = ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   151
          s4o.print_integer(action_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   152
          s4o.print(";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   153
          action_number = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   154
          wanted_sfcdeclaration = sfcinit_sd;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
          
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   156
          /* actions table initialisation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   157
          s4o.print(s4o.indent_spaces + "ACTION temp_action = {0, 0, 0, 0, 0, 0};\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   158
          s4o.print(s4o.indent_spaces + "for(i = 0; i < ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   159
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   160
          s4o.print("__nb_actions; i++) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   161
          s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
          s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   163
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   164
          s4o.print("__action_list[i] = temp_action;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   165
          s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   166
          s4o.print(s4o.indent_spaces + "}\n");
125
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 120
diff changeset
   167
          
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 120
diff changeset
   168
          /* last_ticktime initialisation */
160
59d58f5e6caa Adding support for compiling struct data types
lbessard
parents: 141
diff changeset
   169
          s4o.print(s4o.indent_spaces);
125
7ec16536bc87 Modifying time qualifier in SFC to take real time enlapsed instead of theoric period time
lbessard
parents: 120
diff changeset
   170
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   171
          s4o.print("__lasttick_time = __CURRENT_TIME;\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   173
        case stepdef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
          s4o.print("// Steps definitions\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   175
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   176
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   177
          s4o.print("\n");
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
        case actiondef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
          s4o.print("// Actions definitions\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
        case stepundef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
          s4o.print("// Steps undefinitions\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   187
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   188
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
        case actionundef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
          s4o.print("// Actions undefinitions\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
          for(int i = 0; i < symbol->n; i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
            symbol->elements[i]->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   197
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   199
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   202
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   203
    void *visit(initial_step_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   204
      switch (wanted_sfcdeclaration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   205
        case stepcount_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   206
        case sfcdecl_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   207
          step_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
        case sfcinit_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   210
          s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   211
          print_variable_prefix();
141
d2dc99c319b6 Adding support for transition debugging
lbessard
parents: 125
diff changeset
   212
          s4o.print("__step_list[");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   213
          s4o.print_integer(step_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
          s4o.print("].state = 1;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
          step_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
        case stepdef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   218
          s4o.print("#define ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
          symbol->step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
          s4o.print(" ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
          s4o.print_integer(step_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
          step_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   226
        case stepundef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   227
          s4o.print("#undef ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   228
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   229
          symbol->step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   230
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   231
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   232
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   233
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   234
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   235
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   236
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   237
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   238
    void *visit(step_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   239
      switch (wanted_sfcdeclaration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   240
        case stepcount_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   241
        case sfcdecl_sd:
119
4cbf71106b66 Bug with C code generation for SFC when more than one sfc_network in one sequential_function_chart fixed
lbessard
parents: 116
diff changeset
   242
        case sfcinit_sd:
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   243
          step_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   244
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   245
        case stepdef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   246
          s4o.print("#define ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   247
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   248
          symbol->step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   249
          s4o.print(" ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   250
          s4o.print_integer(step_number);
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
          step_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   253
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   254
        case stepundef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   255
          s4o.print("#undef ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   256
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   257
          symbol->step_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   258
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   259
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   260
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   264
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
    void *visit(transition_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
      switch (wanted_sfcdeclaration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
        case sfcdecl_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
          transition_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   271
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   272
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   273
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   274
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   275
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   276
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   277
    void *visit(action_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   278
      switch (wanted_sfcdeclaration) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   279
        case actiondef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   280
          s4o.print("#define ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   281
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   282
          symbol->action_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   283
          s4o.print(" ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   284
          s4o.print_integer(action_number);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
          s4o.print("\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
          action_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   288
        case actionundef_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
          s4o.print("#undef ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
          s4o.print(SFC_STEP_ACTION_PREFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
          symbol->action_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
          s4o.print("\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 actioncount_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
        case sfcdecl_sd:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   296
          action_number++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   297
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
        default:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   299
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   301
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
    void *visit(instruction_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   307
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   308
    void *visit(statement_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   309
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   310
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   311
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   312
}; /* generate_c_sfcdecl_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313