stage4/generate_c/generate_c_st.cc
author laurent
Fri, 02 Sep 2011 18:15:55 +0200
changeset 347 44ff2a6fcadc
parent 344 8f71c46a0a55
child 349 b826f13c260e
permissions -rwxr-xr-x
Fix case statement in ST, adding support for enumerated types
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: 258
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: 258
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: 258
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: 258
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: 258
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: 258
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: 258
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: 258
diff changeset
    11
 *
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 258
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: 258
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: 258
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: 258
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: 258
diff changeset
    16
 *
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 258
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: 258
diff changeset
    18
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    19
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    23
 * Based on the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    24
 * FINAL DRAFT - IEC 61131-3, 2nd Ed. (2001-12-10)
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    30
 * Conversion of st statements (i.e. ST code).
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    31
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    32
 * This is part of the 4th stage that generates
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 258
diff changeset
    33
 * a C source program equivalent to the IL and ST, or SFC
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    34
 * code.
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    43
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    44
class generate_c_st_c: public generate_c_typedecl_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    45
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    46
  public:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    47
    typedef enum {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    48
      expression_vg,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    49
      assignment_vg,
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
    50
      complextype_base_vg,
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
    51
      complextype_suffix_vg,
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    52
      fparam_output_vg
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    53
    } variablegeneration_t;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    54
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    55
    typedef enum {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    56
      single_cg,
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    57
      subrange_cg,
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    58
      none_cg
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    59
    } casegeneration_t;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    60
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
    /* When calling a function block, we must first find it's type,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
     * by searching through the declarations of the variables currently
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
     * in scope.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
     * This class does just that...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
     * A new class is instantiated whenever we begin generating the code
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
     * for a function block type declaration, or a program declaration.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
     * This object instance will then later be called while the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
     * function block's or the program's body is being handled.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
     * Note that functions cannot contain calls to function blocks,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
     * so we do not create an object instance when handling
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
     * a function declaration.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
    search_fb_instance_decl_c *search_fb_instance_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
    /* When compiling st code, it becomes necessary to determine the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    78
     * data type of st expressions. To do this, we must first find the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    79
     * st operand's declaration, within the scope of the function block
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    80
     * or function currently being processed.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    81
     * The following object does just that...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    82
     * This object instance will then later be called while the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
     * remaining st code is being handled.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
    search_expression_type_c *search_expression_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    86
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
    search_varfb_instance_type_c *search_varfb_instance_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    89
    search_base_type_c search_base_type;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    90
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    91
    symbol_c* current_array_type;
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
    92
    symbol_c* current_param_type;
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    93
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    94
    int fcall_number;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    95
    symbol_c *fbname;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    96
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    97
    bool first_subrange_case_list;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
    98
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    99
    variablegeneration_t wanted_variablegeneration;
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   100
    casegeneration_t wanted_casegeneration;
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   101
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
  public:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   103
    generate_c_st_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
   104
    : generate_c_typedecl_c(s4o_ptr) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
      search_fb_instance_decl = new search_fb_instance_decl_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
      search_expression_type = new search_expression_type_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
      search_varfb_instance_type = new search_varfb_instance_type_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
      this->set_variable_prefix(variable_prefix);
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   109
      current_array_type = NULL;
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   110
      current_param_type = NULL;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   111
      fcall_number = 0;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   112
      fbname = name;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   113
      wanted_variablegeneration = expression_vg;
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   114
      wanted_casegeneration = none_cg;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
    virtual ~generate_c_st_c(void) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
      delete search_fb_instance_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
      delete search_expression_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   120
      delete search_varfb_instance_type;
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   124
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   125
    void generate(statement_list_c *stl) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   126
      stl->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   128
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   131
void *print_getter(symbol_c *symbol) {
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   132
  unsigned int vartype = search_varfb_instance_type->get_vartype(symbol);
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   133
  if (wanted_variablegeneration == fparam_output_vg) {
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   134
  	if (vartype == search_var_instance_decl_c::external_vt)
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   135
      s4o.print(GET_EXTERNAL_BY_REF);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   136
    else if (vartype == search_var_instance_decl_c::located_vt)
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   137
      s4o.print(GET_LOCATED_BY_REF);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   138
    else
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   139
      s4o.print(GET_VAR_BY_REF);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   140
  }
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   141
  else {
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   142
	if (vartype == search_var_instance_decl_c::external_vt)
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   143
	  s4o.print(GET_EXTERNAL);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   144
	else if (vartype == search_var_instance_decl_c::located_vt)
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   145
	  s4o.print(GET_LOCATED);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   146
	else
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   147
	  s4o.print(GET_VAR);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   148
  }
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   149
  s4o.print("(");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   150
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   151
  variablegeneration_t old_wanted_variablegeneration = wanted_variablegeneration;
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   152
  wanted_variablegeneration = complextype_base_vg;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   153
  symbol->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   154
  if (search_varfb_instance_type->type_is_complex())
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   155
    s4o.print(",");
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   156
  wanted_variablegeneration = complextype_suffix_vg;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   157
  symbol->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   158
  s4o.print(")");
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   159
  wanted_variablegeneration = old_wanted_variablegeneration;
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   160
  return NULL;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   161
}
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   162
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   163
void *print_setter(symbol_c* symbol,
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   164
		symbol_c* type,
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   165
		symbol_c* value,
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   166
		symbol_c* fb_symbol = NULL,
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   167
		symbol_c* fb_value = NULL) {
302
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   168
  
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   169
  unsigned int vartype = search_varfb_instance_type->get_vartype(symbol);
231
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   170
  if (vartype == search_var_instance_decl_c::external_vt) {
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   171
    symbolic_variable_c *variable = dynamic_cast<symbolic_variable_c *>(symbol);
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   172
    /* TODO Find a solution for forcing global complex variables */
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   173
    if (variable != NULL) {
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   174
      s4o.print(SET_EXTERNAL);
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   175
      s4o.print("(");
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   176
      variable->var_name->accept(*this);
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   177
      s4o.print(",");
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   178
    }
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   179
    else {
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   180
      s4o.print(SET_COMPLEX_EXTERNAL);
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   181
      s4o.print("(");
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   182
    }
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   183
  }
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   184
  else {
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   185
    if (vartype == search_var_instance_decl_c::located_vt)
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   186
      s4o.print(SET_LOCATED);
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   187
    else
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   188
      s4o.print(SET_VAR);
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   189
    s4o.print("(");
b8527b0abe75 Adding support for forcing global without perturbation from setting external
laurent
parents: 228
diff changeset
   190
  }
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   191
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   192
  if (fb_symbol != NULL) {
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   193
    print_variable_prefix();
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   194
    fb_symbol->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   195
    s4o.print(".");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   196
  }
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   197
  else
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   198
    wanted_variablegeneration = complextype_base_vg;
302
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   199
  
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   200
  symbol->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   201
  s4o.print(",");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   202
  wanted_variablegeneration = expression_vg;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   203
  print_check_function(type, value, fb_value);
302
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   204
  /* We need to call search_varfb_instance_type->get_vartype() again, as it may have been called
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   205
   * again since we called it in the beginning of this print_setter() function.
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   206
   * This make sure the call to search_varfb_instance_type->type_is_complex() will return
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   207
   * the correct value regarding our 'symbol'.
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   208
   */
d120740a6b58 Fixing bug related to setting array variables with values coming from other variables
Mario de Sousa <msousa@fe.up.pt>
parents: 298
diff changeset
   209
  search_varfb_instance_type->get_vartype(symbol);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   210
  if (search_varfb_instance_type->type_is_complex()) {
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   211
    s4o.print(",");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   212
    wanted_variablegeneration = complextype_suffix_vg;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   213
    symbol->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   214
  }
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   215
  s4o.print(")");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   216
  wanted_variablegeneration = expression_vg;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   217
  return NULL;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   218
}
146
eef5e62048c7 Adding support for EN/ENO params in function and function blocks (standard function not supported yet)
lbessard
parents: 145
diff changeset
   219
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   220
/********************************/
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   221
/* B 1.3.3 - Derived data types */
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   222
/********************************/
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   223
/*  signed_integer DOTDOT signed_integer */
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   224
void *visit(subrange_c *symbol) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   225
  switch (wanted_casegeneration) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   226
    case subrange_cg:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   227
      s4o.print("case_expression >= ");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   228
      symbol->lower_limit->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   229
      s4o.print(" && case_expression <= ");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   230
      symbol->upper_limit->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   231
      break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   232
    default:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   233
      break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   234
  }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   235
  return NULL;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   236
}
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
   237
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   238
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   239
/* B 1.4 - Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   240
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   241
void *visit(symbolic_variable_c *symbol) {
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   242
  unsigned int vartype;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   243
  if (wanted_variablegeneration == complextype_base_vg)
298
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   244
         generate_c_base_c::visit(symbol);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   245
  else if (wanted_variablegeneration == complextype_suffix_vg)
298
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   246
         return NULL;
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   247
  else if (this->is_variable_prefix_null()) {
298
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   248
         vartype = search_varfb_instance_type->get_vartype(symbol);
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   249
         if (wanted_variablegeneration == fparam_output_vg) {
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   250
           s4o.print("&(");
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   251
           generate_c_base_c::visit(symbol);
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   252
           s4o.print(")");
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   253
         } 
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   254
         else {
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   255
           generate_c_base_c::visit(symbol);
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   256
         }
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   257
  }
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   258
  else
298
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   259
      print_getter(symbol);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   260
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   264
/* B.1.4.1   Directly Represented Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
// direct_variable: direct_variable_token   {$$ = new direct_variable_c($1);};
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
void *visit(direct_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
  TRACE("direct_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
  /* Do not use print_token() as it will change everything into uppercase */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
  if (strlen(symbol->value) == 0) ERROR;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   271
  if (this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   272
    if (wanted_variablegeneration != fparam_output_vg)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   273
	  s4o.print("*(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   274
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   275
  else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   276
    switch (wanted_variablegeneration) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   277
      case expression_vg:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   278
  	    s4o.print(GET_LOCATED);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   279
  	    s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   280
  	    break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   281
      case fparam_output_vg:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   282
        s4o.print(GET_LOCATED_BY_REF);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   283
        s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   284
        break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   285
      default:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   286
        break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   287
    }
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   288
  }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
  this->print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
  s4o.printlocation(symbol->value + 1);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   291
  if ((this->is_variable_prefix_null() && wanted_variablegeneration != fparam_output_vg) ||
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   292
	  wanted_variablegeneration != assignment_vg)
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   293
    s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   294
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   296
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   297
/*************************************/
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   298
/* B.1.4.2   Multi-element Variables */
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   299
/*************************************/
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   300
221
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   301
// SYM_REF2(structured_variable_c, record_variable, field_selector)
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   302
void *visit(structured_variable_c *symbol) {
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   303
  TRACE("structured_variable_c");
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   304
  switch (wanted_variablegeneration) {
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   305
    case complextype_base_vg:
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   306
      symbol->record_variable->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   307
      break;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   308
    case complextype_suffix_vg:
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   309
      symbol->record_variable->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   310
      s4o.print(".");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   311
      symbol->field_selector->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   312
      break;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   313
    default:
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   314
      if (this->is_variable_prefix_null()) {
221
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   315
    	symbol->record_variable->accept(*this);
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   316
    	s4o.print(".");
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   317
    	symbol->field_selector->accept(*this);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   318
      }
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   319
      else
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   320
    	print_getter(symbol);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   321
      break;
221
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   322
  }
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   323
  return NULL;
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   324
}
c6aed7e5f070 Adding support for flags on Function Block variables for marking which variable must be debugged, retained or is forced
laurent
parents: 220
diff changeset
   325
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   326
/*  subscripted_variable '[' subscript_list ']' */
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   327
//SYM_REF2(array_variable_c, subscripted_variable, subscript_list)
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   328
void *visit(array_variable_c *symbol) {
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   329
  switch (wanted_variablegeneration) {
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   330
    case complextype_base_vg:
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   331
      symbol->subscripted_variable->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   332
      break;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   333
    case complextype_suffix_vg:
238
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   334
      symbol->subscripted_variable->accept(*this);
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   335
321
a96399ab57c2 Add better comments, and change name of functions to clarify what they do.
Mario de Sousa <msousa@fe.up.pt>
parents: 309
diff changeset
   336
      current_array_type = search_varfb_instance_type->get_type_id(symbol->subscripted_variable);
238
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   337
      if (current_array_type == NULL) ERROR;
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   338
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   339
      s4o.print(".table");
298
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   340
      wanted_variablegeneration = expression_vg;
238
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   341
      symbol->subscript_list->accept(*this);
298
022a874149ce Fixing code generation of array indexes in Function Blocks.
Mario de Sousa <msousa@fe.up.pt>
parents: 283
diff changeset
   342
      wanted_variablegeneration = complextype_suffix_vg;
238
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   343
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   344
      current_array_type = NULL;
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   345
      break;
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   346
    default:
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   347
      if (this->is_variable_prefix_null()) {
238
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   348
    	symbol->subscripted_variable->accept(*this);
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   349
321
a96399ab57c2 Add better comments, and change name of functions to clarify what they do.
Mario de Sousa <msousa@fe.up.pt>
parents: 309
diff changeset
   350
    	current_array_type = search_varfb_instance_type->get_type_id(symbol->subscripted_variable);
238
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   351
    	if (current_array_type == NULL) ERROR;
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   352
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   353
    	s4o.print(".table");
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   354
        symbol->subscript_list->accept(*this);
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   355
0919986a5c98 Bug when trying to get type of elements in a big complex structure fixed
laurent
parents: 237
diff changeset
   356
        current_array_type = NULL;
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   357
      }
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   358
      else
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   359
    	print_getter(symbol);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   360
      break;
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   361
  }
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   362
  return NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   363
}
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   364
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   365
/* subscript_list ',' subscript */
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   366
void *visit(subscript_list_c *symbol) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   367
  for (int i =  0; i < symbol->n; i++) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   368
    s4o.print("[__");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   369
    current_array_type->accept(*this);
309
f93bcada0f51 Fix bug when declaring data type directly derived from array type
laurent
parents: 302
diff changeset
   370
    s4o.print("_TRANSIDX(");
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   371
    print_integer(i);
309
f93bcada0f51 Fix bug when declaring data type directly derived from array type
laurent
parents: 302
diff changeset
   372
    s4o.print(",");
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   373
    symbol->elements[i]->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   374
    s4o.print(")]");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   375
  }
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   376
  return NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   377
}
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   378
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   379
/******************************************/
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   380
/* B 1.4.3 - Declaration & Initialisation */
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   381
/******************************************/
237
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   382
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   383
/* helper symbol for structure_initialization */
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   384
/* structure_element_initialization_list ',' structure_element_initialization */
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   385
void *visit(structure_element_initialization_list_c *symbol) {
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   386
  generate_c_structure_initialization_c *structure_initialization = new generate_c_structure_initialization_c(&s4o);
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   387
  structure_initialization->init_structure_default(this->current_param_type);
237
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   388
  structure_initialization->init_structure_values(symbol);
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   389
  delete structure_initialization;
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   390
  return NULL;
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   391
}
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   392
237
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   393
/* helper symbol for array_initialization */
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   394
/* array_initial_elements_list ',' array_initial_elements */
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   395
void *visit(array_initial_elements_list_c *symbol) {
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   396
  generate_c_array_initialization_c *array_initialization = new generate_c_array_initialization_c(&s4o);
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   397
  array_initialization->init_array_size(this->current_param_type);
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   398
  array_initialization->init_array_values(symbol);
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   399
  delete array_initialization;
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   400
  return NULL;
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   401
}
cece842c7417 Adding support for using arrays in POU interface
laurent
parents: 236
diff changeset
   402
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   403
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
/* B.3 - Language ST (Structured Text) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   405
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
/* B 3.1 - Expressions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
void *visit(or_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   410
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   411
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   412
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   414
  if (search_expression_type->is_bool_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   415
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " || ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " | ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
void *visit(xor_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   424
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   425
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   426
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   427
  if (search_expression_type->is_bool_type(left_type)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   428
    s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   429
    symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
    s4o.print(" && !");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
    s4o.print(") || (!");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
    symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   434
    s4o.print(" && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   435
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   436
    s4o.print(")");
130
a8263f33123f Fixed missing return in XOR operator code gen.
etisserant
parents: 123
diff changeset
   437
    return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   439
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   440
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " ^ ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   441
  ERROR;
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(and_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   446
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   447
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   448
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   449
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   450
  if (search_expression_type->is_bool_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   452
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " & ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   454
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   455
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   456
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   457
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   458
void *visit(equ_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   459
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   460
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   461
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   462
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   463
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   464
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
    return print_compare_function("__eq_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " == ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   467
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   468
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   469
void *visit(notequ_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   470
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   471
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   472
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   473
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   474
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   475
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   476
    return print_compare_function("__ne_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   477
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " != ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   478
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   479
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   480
void *visit(lt_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   484
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   485
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   486
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
    return print_compare_function("__lt_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   488
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   489
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " < ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   490
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   491
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   494
void *visit(gt_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   497
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   499
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   500
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
    return print_compare_function("__gt_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   502
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   503
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " > ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   504
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   505
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   506
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   507
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   508
void *visit(le_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   509
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   510
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   511
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   512
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   513
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   514
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   515
    return print_compare_function("__le_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   516
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   517
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " <= ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   518
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   519
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   520
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   521
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   522
void *visit(ge_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   523
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   524
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   525
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   527
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   528
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   529
    return print_compare_function("__ge_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   530
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   531
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " >= ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   532
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   533
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   534
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   535
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   536
void *visit(add_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   537
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   538
	symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   539
	if ((typeid(*left_type) == typeid(time_type_name_c) && typeid(*right_type) == typeid(time_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   540
      (typeid(*left_type) == typeid(tod_type_name_c) && typeid(*right_type) == typeid(time_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   541
      (typeid(*left_type) == typeid(dt_type_name_c) && typeid(*right_type) == typeid(time_type_name_c)))
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   542
    return print_binary_function("__TIME_ADD", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   543
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   544
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   545
  if (search_expression_type->is_integer_type(left_type) || search_expression_type->is_real_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   546
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " + ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   547
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   548
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   549
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   550
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   551
void *visit(sub_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   552
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   553
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   554
  if ((typeid(*left_type) == typeid(time_type_name_c) && typeid(*right_type) == typeid(time_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   555
      (typeid(*left_type) == typeid(date_type_name_c) && typeid(*right_type) == typeid(date_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   556
      (typeid(*left_type) == typeid(tod_type_name_c) && typeid(*right_type) == typeid(time_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   557
      (typeid(*left_type) == typeid(tod_type_name_c) && typeid(*right_type) == typeid(tod_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   558
      (typeid(*left_type) == typeid(dt_type_name_c) && typeid(*right_type) == typeid(time_type_name_c)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   559
      (typeid(*left_type) == typeid(dt_type_name_c) && typeid(*right_type) == typeid(dt_type_name_c)))
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   560
    return print_binary_function("__TIME_SUB", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   561
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   562
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   563
  if (search_expression_type->is_integer_type(left_type) || search_expression_type->is_real_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   564
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " - ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   565
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   566
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   567
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   568
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   569
void *visit(mul_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   570
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   571
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   572
  if ((typeid(*left_type) == typeid(time_type_name_c) && search_expression_type->is_integer_type(right_type)) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   573
      (typeid(*left_type) == typeid(time_type_name_c) && search_expression_type->is_real_type(right_type)))
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   574
    return print_binary_function("__TIME_MUL", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   575
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   576
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   577
  if (search_expression_type->is_integer_type(left_type) || search_expression_type->is_real_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   578
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " * ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   579
  ERROR;
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(div_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   584
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   585
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   586
  if ((typeid(*left_type) == typeid(time_type_name_c) && search_expression_type->is_integer_type(right_type)) ||
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   587
      (typeid(*left_type) == typeid(time_type_name_c) && search_expression_type->is_real_type(right_type)))
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   588
    return print_binary_function("__TIME_DIV", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   589
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   590
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   591
  if (search_expression_type->is_integer_type(left_type) || search_expression_type->is_real_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   592
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " / ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   593
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   594
  return NULL;
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
void *visit(mod_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   598
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   599
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   600
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   601
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   602
  if (search_expression_type->is_integer_type(left_type) || search_expression_type->is_real_type(left_type)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   603
    s4o.print("((");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   604
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   605
    s4o.print(" == 0)?0:");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   606
    print_binary_expression(symbol->l_exp, symbol->r_exp, " % ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   607
    s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   608
    return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   609
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   610
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   611
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   612
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   613
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   614
/* TODO: power expression... */
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   615
void *visit(power_expression_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   616
  ERROR; 
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   617
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " ** ");
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   618
}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   619
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   620
void *visit(neg_expression_c *symbol) {
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   621
  return print_unary_expression(symbol->exp, " -");
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   622
}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   623
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   624
void *visit(not_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   625
  symbol_c *exp_type = search_expression_type->get_type(symbol->exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   626
  if (search_expression_type->is_binary_type(exp_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   627
    return print_unary_expression(symbol->exp, search_expression_type->is_bool_type(exp_type)?"!":"~");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   628
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   629
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   630
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   631
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   632
void *visit(function_invocation_c *symbol) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   633
  symbol_c* function_type_prefix = NULL;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   634
  symbol_c* function_name = NULL;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   635
  symbol_c* function_type_suffix = NULL;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   636
  DECLARE_PARAM_LIST()
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   637
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   638
  symbol_c *parameter_assignment_list = NULL;
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   639
  if (NULL != symbol->   formal_param_list) parameter_assignment_list = symbol->   formal_param_list;
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   640
  if (NULL != symbol->nonformal_param_list) parameter_assignment_list = symbol->nonformal_param_list;
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   641
  if (NULL == parameter_assignment_list) ERROR;
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   642
233
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   643
  function_call_param_iterator_c function_call_param_iterator(symbol);
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   644
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   645
  function_declaration_c *f_decl = function_symtable.find_value(symbol->function_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   646
  if (f_decl == function_symtable.end_value()) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   647
    /* The function called is not in the symtable, so we test if it is a
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   648
     * standard function defined in standard */
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   649
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   650
    function_type_t current_function_type = get_function_type((identifier_c *)symbol->function_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   651
    if (current_function_type == function_none) ERROR;
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   652
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   653
    symbol_c *function_return_type = search_expression_type->get_type(symbol);
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   654
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   655
    int nb_param = ((list_c *)parameter_assignment_list)->n;
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   656
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   657
    symbol_c *en_param_name = (symbol_c *)(new identifier_c("EN"));
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   658
    /* Get the value from EN param */
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   659
    symbol_c *EN_param_value = function_call_param_iterator.search_f(en_param_name);
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   660
    if (EN_param_value == NULL)
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   661
      EN_param_value = (symbol_c*)(new boolean_literal_c((symbol_c*)(new bool_type_name_c()), new boolean_true_c()));
167
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   662
    else
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   663
      nb_param --;
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   664
    ADD_PARAM_LIST(en_param_name, EN_param_value, (symbol_c*)(new bool_type_name_c()), function_param_iterator_c::direction_in)
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   665
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   666
    symbol_c *eno_param_name = (symbol_c *)(new identifier_c("ENO"));
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   667
    /* Get the value from ENO param */
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   668
    symbol_c *ENO_param_value = function_call_param_iterator.search_f(eno_param_name);
167
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   669
    if (ENO_param_value != NULL)
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   670
      nb_param --;
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   671
    ADD_PARAM_LIST(eno_param_name, ENO_param_value, (symbol_c*)(new bool_type_name_c()), function_param_iterator_c::direction_out)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   672
146
eef5e62048c7 Adding support for EN/ENO params in function and function blocks (standard function not supported yet)
lbessard
parents: 145
diff changeset
   673
    #include "st_code_gen.c"
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   674
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   675
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   676
  else {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   677
	function_name = symbol->function_name;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   678
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   679
	/* loop through each function parameter, find the value we should pass
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   680
     * to it, and then output the c equivalent...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   681
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   682
    function_param_iterator_c fp_iterator(f_decl);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   683
    identifier_c *param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   684
    for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   685
      
233
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   686
      symbol_c *param_type = fp_iterator.param_type();
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   687
      if (param_type == NULL) ERROR;
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   688
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   689
      function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   690
      
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   691
      /* Get the value from a foo(<param_name> = <param_value>) style call */
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   692
      symbol_c *param_value = function_call_param_iterator.search_f(param_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   693
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   694
      /* Get the value from a foo(<param_value>) style call */
233
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   695
      if (param_value == NULL) {
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   696
        param_value = function_call_param_iterator.next_nf();
233
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   697
        if (param_value != NULL && fp_iterator.is_en_eno_param_implicit()) ERROR;
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   698
      }
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   699
      
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   700
      if (param_value == NULL && param_direction == function_param_iterator_c::direction_in) {
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   701
        /* No value given for parameter, so we must use the default... */
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   702
        /* First check whether default value specified in function declaration...*/
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   703
        param_value = fp_iterator.default_value();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   704
      }
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   705
      
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   706
      ADD_PARAM_LIST(param_name, param_value, param_type, param_direction)
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   707
    } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   708
    // symbol->parameter_assignment->accept(*this);
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   709
  }
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   710
  
233
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   711
  if (function_call_param_iterator.next_nf() != NULL) ERROR;
3d23a68183d3 Bug on standard functions called with literals fixed
laurent
parents: 231
diff changeset
   712
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   713
  bool has_output_params = false;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   714
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   715
  if (!this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   716
    PARAM_LIST_ITERATOR() {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   717
	  if ((PARAM_DIRECTION == function_param_iterator_c::direction_out ||
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   718
		   PARAM_DIRECTION == function_param_iterator_c::direction_inout) &&
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   719
		  PARAM_VALUE != NULL) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   720
	    if (!has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   721
		  has_output_params = true;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   722
		}
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   723
	  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   724
    }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   725
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   726
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   727
  if (function_type_prefix != NULL) {
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   728
    s4o.print("(");
336
229eb3e29216 Fix bug in function calls with literal parameters
laurent
parents: 321
diff changeset
   729
    search_expression_type->default_literal_type(function_type_prefix)->accept(*this);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   730
    s4o.print(")");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   731
  }
336
229eb3e29216 Fix bug in function calls with literal parameters
laurent
parents: 321
diff changeset
   732
  if (function_type_suffix != NULL) {
344
8f71c46a0a55 Fix bug in suffix of inlinefcall call in ST and IL
laurent
parents: 336
diff changeset
   733
	function_type_suffix = search_expression_type->default_literal_type(function_type_suffix);
336
229eb3e29216 Fix bug in function calls with literal parameters
laurent
parents: 321
diff changeset
   734
  }
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   735
  if (has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   736
	fcall_number++;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   737
	s4o.print("__");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   738
    fbname->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   739
    s4o.print("_");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   740
    function_name->accept(*this);
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   741
    if (function_type_suffix != NULL)
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   742
      function_type_suffix->accept(*this);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   743
    s4o.print_integer(fcall_number);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   744
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   745
  else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   746
    function_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   747
    if (function_type_suffix != NULL)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   748
      function_type_suffix->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   749
  }
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   750
  s4o.print("(");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   751
  s4o.indent_right();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   752
  
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   753
  int nb_param = 0;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   754
  PARAM_LIST_ITERATOR() {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   755
    symbol_c *param_value = PARAM_VALUE;
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   756
    current_param_type = PARAM_TYPE;
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   757
          
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   758
    switch (PARAM_DIRECTION) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   759
      case function_param_iterator_c::direction_in:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   760
    	if (nb_param > 0)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   761
    	  s4o.print(",\n"+s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   762
    	if (param_value == NULL) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   763
          /* If not, get the default value of this variable's type */
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   764
          param_value = (symbol_c *)current_param_type->accept(*type_initial_value_c::instance());
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   765
        }
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   766
        if (param_value == NULL) ERROR;
216
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   767
        s4o.print("(");
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   768
        if (search_expression_type->is_literal_integer_type(current_param_type))
220
f332b62cd2c1 Bug with ULINT correction fixed
laurent
parents: 217
diff changeset
   769
          search_expression_type->lint_type_name.accept(*this);
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   770
        else if (search_expression_type->is_literal_real_type(current_param_type))
220
f332b62cd2c1 Bug with ULINT correction fixed
laurent
parents: 217
diff changeset
   771
          search_expression_type->lreal_type_name.accept(*this);
216
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   772
        else
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   773
          current_param_type->accept(*this);
216
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   774
        s4o.print(")");
235
ed66dc50f31a Bug on generate_c_inlinefcall fixed
laurent
parents: 233
diff changeset
   775
        print_check_function(current_param_type, param_value);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   776
        nb_param++;
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   777
        break;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   778
      case function_param_iterator_c::direction_out:
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   779
      case function_param_iterator_c::direction_inout:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   780
    	if (!has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   781
          if (nb_param > 0)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   782
        	s4o.print(",\n"+s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   783
    	  if (param_value == NULL)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   784
            s4o.print("NULL");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   785
          else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   786
            wanted_variablegeneration = fparam_output_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   787
            param_value->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   788
            wanted_variablegeneration = expression_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   789
          }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   790
    	  nb_param++;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   791
    	}
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   792
        break;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   793
      case function_param_iterator_c::direction_extref:
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   794
        /* TODO! */
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   795
        ERROR;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   796
        break;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   797
    } /* switch */
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   798
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   799
  if (has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   800
    if (nb_param > 0)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   801
      s4o.print(",\n"+s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   802
    s4o.print(FB_FUNCTION_PARAM);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   803
  }
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   804
  s4o.print(")");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   805
  s4o.indent_left();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   806
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   807
  CLEAR_PARAM_LIST()
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   808
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   809
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   810
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   811
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   812
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   813
/* B 3.2 Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   814
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   815
void *visit(statement_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   816
  return print_list(symbol, s4o.indent_spaces, ";\n" + s4o.indent_spaces, ";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   817
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   818
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   819
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   820
/* B 3.2.1 Assignment Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   821
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   822
void *visit(assignment_statement_c *symbol) {
321
a96399ab57c2 Add better comments, and change name of functions to clarify what they do.
Mario de Sousa <msousa@fe.up.pt>
parents: 309
diff changeset
   823
  symbol_c *left_type = search_varfb_instance_type->get_type_id(symbol->l_exp);
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   824
  
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   825
  if (this->is_variable_prefix_null()) {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   826
    symbol->l_exp->accept(*this);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   827
    s4o.print(" = ");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   828
    print_check_function(left_type, symbol->r_exp);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   829
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   830
  else {
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   831
	print_setter(symbol->l_exp, left_type, symbol->r_exp);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   832
  }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   833
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   834
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   835
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   836
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   837
/* B 3.2.2 Subprogram Control Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   838
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   839
283
214d3fdee596 fixing C code generation of return_statement_c and exit_statement_c
Mario de Sousa <msousa@fe.up.pt>
parents: 282
diff changeset
   840
void *visit(return_statement_c *symbol) {
214d3fdee596 fixing C code generation of return_statement_c and exit_statement_c
Mario de Sousa <msousa@fe.up.pt>
parents: 282
diff changeset
   841
  s4o.print("goto "); s4o.print(END_LABEL);
214d3fdee596 fixing C code generation of return_statement_c and exit_statement_c
Mario de Sousa <msousa@fe.up.pt>
parents: 282
diff changeset
   842
  return NULL;
214d3fdee596 fixing C code generation of return_statement_c and exit_statement_c
Mario de Sousa <msousa@fe.up.pt>
parents: 282
diff changeset
   843
}
214d3fdee596 fixing C code generation of return_statement_c and exit_statement_c
Mario de Sousa <msousa@fe.up.pt>
parents: 282
diff changeset
   844
214d3fdee596 fixing C code generation of return_statement_c and exit_statement_c
Mario de Sousa <msousa@fe.up.pt>
parents: 282
diff changeset
   845
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   846
/* fb_name '(' [param_assignment_list] ')' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   847
/* param_assignment_list -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   848
//SYM_REF2(fb_invocation_c, fb_name, param_assignment_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   849
void *visit(fb_invocation_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   850
  TRACE("fb_invocation_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   851
  /* first figure out what is the name of the function block type of the function block being called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   852
  symbol_c *function_block_type_name = this->search_fb_instance_decl->get_type_name(symbol->fb_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   853
    /* should never occur. The function block instance MUST have been declared... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   854
  if (function_block_type_name == NULL) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   855
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   856
  /* Now find the declaration of the function block type being called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   857
  function_block_declaration_c *fb_decl = function_block_type_symtable.find_value(function_block_type_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   858
    /* should never occur. The function block type being called MUST be in the symtable... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   859
  if (fb_decl == function_block_type_symtable.end_value()) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   860
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   861
  /* loop through each function block parameter, find the value we should pass
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   862
   * to it, and then output the c equivalent...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   863
   */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   864
  function_param_iterator_c fp_iterator(fb_decl);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   865
  identifier_c *param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   866
  function_call_param_iterator_c function_call_param_iterator(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   867
  for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   868
    function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
160
59d58f5e6caa Adding support for compiling struct data types
lbessard
parents: 149
diff changeset
   869
    
162
60a124678842 Fixed typo in EN/ENO parameters handling for std library functions
etisserant
parents: 160
diff changeset
   870
    /*fprintf(stderr, "param : %s\n", param_name->value);*/
160
59d58f5e6caa Adding support for compiling struct data types
lbessard
parents: 149
diff changeset
   871
    
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   872
    /* Get the value from a foo(<param_name> = <param_value>) style call */
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   873
    symbol_c *param_value = function_call_param_iterator.search_f(param_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   874
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   875
    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   876
    if (param_value == NULL)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   877
      param_value = function_call_param_iterator.next_nf();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   878
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   879
    symbol_c *param_type = fp_iterator.param_type();
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   880
    if (param_type == NULL) ERROR;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   881
    
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   882
    /* now output the value assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   883
    if (param_value != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   884
      if ((param_direction == function_param_iterator_c::direction_in) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   885
          (param_direction == function_param_iterator_c::direction_inout)) {
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   886
        if (this->is_variable_prefix_null()) {
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   887
          symbol->fb_name->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   888
          s4o.print(".");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   889
          param_name->accept(*this);
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   890
          s4o.print(" = ");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   891
          print_check_function(param_type, param_value);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   892
        }
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   893
        else {
228
43831b683764 Adding support for setter and getter on complex datatype in IL
berem
parents: 226
diff changeset
   894
          print_setter(param_name, param_type, param_value, symbol->fb_name);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   895
        }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   896
        s4o.print(";\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   897
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   898
  } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   899
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   900
  /* now call the function... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   901
  function_block_type_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   902
  s4o.print(FB_FUNCTION_SUFFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   903
  s4o.print("(&");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   904
  print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   905
  symbol->fb_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   906
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   907
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   908
  /* loop through each function parameter, find the variable to which
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   909
   * we should atribute the value of all output or inoutput parameters.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   910
   */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   911
  fp_iterator.reset();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   912
  function_call_param_iterator.reset();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   913
  for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   914
    function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   915
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   916
    /* Get the value from a foo(<param_name> = <param_value>) style call */
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   917
    symbol_c *param_value = function_call_param_iterator.search_f(param_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   918
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   919
    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   920
    if (param_value == NULL)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   921
      param_value = function_call_param_iterator.next_nf();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   922
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   923
    /* now output the value assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   924
    if (param_value != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   925
      if ((param_direction == function_param_iterator_c::direction_out) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   926
          (param_direction == function_param_iterator_c::direction_inout)) {
321
a96399ab57c2 Add better comments, and change name of functions to clarify what they do.
Mario de Sousa <msousa@fe.up.pt>
parents: 309
diff changeset
   927
        symbol_c *param_type = search_varfb_instance_type->get_type_id(param_value);
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 238
diff changeset
   928
        s4o.print(";\n" + s4o.indent_spaces);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   929
        if (this->is_variable_prefix_null()) {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   930
          param_value->accept(*this);
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   931
          s4o.print(" = ");
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   932
          print_check_function(param_type, param_name, symbol->fb_name);
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   933
        }
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   934
        else {
226
29f8ffc203c1 Adding support for setter and getter on complex datatype in ST
laurent
parents: 221
diff changeset
   935
          print_setter(param_value, param_type, param_name, NULL, symbol->fb_name);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   936
        }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   937
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   938
  } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   939
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   940
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   941
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   942
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   943
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   944
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   945
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   946
/* helper symbol for fb_invocation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   947
/* param_assignment_list ',' param_assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   948
void *visit(param_assignment_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   949
  TRACE("param_assignment_list_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   950
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   951
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   952
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   953
//  return print_list(symbol, "", ", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   954
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   955
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   956
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   957
void *visit(input_variable_param_assignment_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   958
  TRACE("input_variable_param_assignment_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   959
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   960
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   961
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   962
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   963
  symbol->variable_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   964
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   965
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   966
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   967
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   968
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   969
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   970
void *visit(output_variable_param_assignment_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   971
  TRACE("output_variable_param_assignment_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   972
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   973
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   974
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   975
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   976
  s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   977
  if (symbol->not_param != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   978
    symbol->not_param->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   979
  symbol->variable_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   980
  s4o.print(" => ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   981
  symbol->variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   982
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   983
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   984
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   985
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   986
// TODO: the NOT symbol in function (block) calls...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   987
void *visit(not_paramassign_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   988
  TRACE("not_paramassign_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   989
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   990
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   991
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   992
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   993
  s4o.print("NOT ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   994
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   995
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   996
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   997
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   998
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   999
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1000
/* B 3.2.3 Selection Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1001
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1002
void *visit(if_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1003
  s4o.print("if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1004
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1005
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1006
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1007
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1008
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1009
  symbol->elseif_statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1010
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1011
  if (symbol->else_statement_list != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1012
    s4o.print(s4o.indent_spaces); s4o.print("} else {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1013
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1014
    symbol->else_statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1015
    s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1016
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1017
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1018
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1019
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1020
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1021
/* helper symbol for if_statement */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1022
void *visit(elseif_statement_list_c *symbol) {return print_list(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1023
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1024
/* helper symbol for elseif_statement_list */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1025
void *visit(elseif_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1026
  s4o.print(s4o.indent_spaces); s4o.print("} else if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1027
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1028
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1029
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1030
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1031
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1032
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1033
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1034
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1035
void *visit(case_statement_c *symbol) {
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1036
  symbol_c *expression_type = search_expression_type->get_type(symbol->expression);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1037
  s4o.print("{\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1038
  s4o.indent_right();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1039
  if (search_base_type.type_is_enumerated(expression_type)) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1040
	s4o.print(s4o.indent_spaces);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1041
	expression_type->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1042
	s4o.print(" case_expression = ");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1043
  }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1044
  else {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1045
	s4o.print(s4o.indent_spaces + "IEC_LINT case_expression = (IEC_LINT)");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1046
  }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1047
  symbol->expression->accept(*this);
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1048
  s4o.print(";\n" + s4o.indent_spaces + "switch (case_expression) {\n");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1049
  s4o.indent_right();
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1050
  wanted_casegeneration = single_cg;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1051
  symbol->case_element_list->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1052
  wanted_casegeneration = subrange_cg;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1053
  s4o.print(s4o.indent_spaces + "default:\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1054
  s4o.indent_right();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1055
  first_subrange_case_list = true;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1056
  symbol->case_element_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1057
  if (symbol->statement_list != NULL) {
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1058
	if (!first_subrange_case_list) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1059
      s4o.print(s4o.indent_spaces + "else {\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1060
      s4o.indent_right();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1061
	}
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1062
    symbol->statement_list->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1063
    if (!first_subrange_case_list) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1064
      s4o.indent_left();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1065
      s4o.print(s4o.indent_spaces + "}\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1066
    }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1067
  }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1068
  s4o.print(s4o.indent_spaces + "break;\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1069
  s4o.indent_left();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1070
  wanted_casegeneration = none_cg;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1071
  s4o.indent_left();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1072
  s4o.print(s4o.indent_spaces + "}\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1073
  s4o.indent_left();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1074
  s4o.print(s4o.indent_spaces + "}");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1075
  return NULL;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1076
}
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1077
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1078
/* helper symbol for case_statement */
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1079
void *visit(case_element_list_c *symbol) {return print_list(symbol);}
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1080
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1081
void *visit(case_element_c *symbol) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1082
  case_element_iterator_c *case_element_iterator;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1083
  symbol_c* element = NULL;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1084
  bool first_element = true;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1085
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1086
  switch (wanted_casegeneration) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1087
    case single_cg:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1088
      case_element_iterator = new case_element_iterator_c(symbol->case_list, case_element_iterator_c::element_single);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1089
      for (element = case_element_iterator->next(); element != NULL; element = case_element_iterator->next()) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1090
        if (first_element) first_element = false;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1091
    	s4o.print(s4o.indent_spaces + "case ");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1092
        element->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1093
        s4o.print(":\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1094
      }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1095
      delete case_element_iterator;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1096
      break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1097
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1098
    case subrange_cg:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1099
      case_element_iterator = new case_element_iterator_c(symbol->case_list, case_element_iterator_c::element_subrange);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1100
      for (element = case_element_iterator->next(); element != NULL; element = case_element_iterator->next()) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1101
        if (first_element) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1102
          if (first_subrange_case_list) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1103
            s4o.print(s4o.indent_spaces + "if (");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1104
            first_subrange_case_list = false;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1105
          }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1106
          else {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1107
        	  s4o.print(s4o.indent_spaces + "else if (");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1108
          }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1109
          first_element = false;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1110
        }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1111
        else {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1112
          s4o.print(" && ");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1113
        }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1114
        element->accept(*this);
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1115
      }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1116
      delete case_element_iterator;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1117
      if (!first_element) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1118
        s4o.print(") {\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1119
      }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1120
      break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1121
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1122
    default:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1123
      break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1124
  }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1125
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1126
  if (!first_element) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1127
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1128
    symbol->statement_list->accept(*this);
347
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1129
    switch (wanted_casegeneration) {
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1130
      case single_cg:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1131
        s4o.print(s4o.indent_spaces + "break;\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1132
        s4o.indent_left();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1133
        break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1134
      case subrange_cg:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1135
    	s4o.indent_left();
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1136
  	    s4o.print(s4o.indent_spaces + "}\n");
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1137
  	    break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1138
      default:
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1139
        break;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1140
    }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1141
  }
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1142
  return NULL;
44ff2a6fcadc Fix case statement in ST, adding support for enumerated types
laurent
parents: 344
diff changeset
  1143
}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1144
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1145
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1146
/* B 3.2.4 Iteration Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1147
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1148
void *visit(for_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1149
  s4o.print("for(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1150
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1151
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1152
  symbol->beg_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1153
  s4o.print("; ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1154
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1155
  s4o.print(" != ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1156
  symbol->end_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1157
  s4o.print("; ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1158
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1159
  if (symbol->by_expression != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1160
    s4o.print(" += ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1161
    symbol->by_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1162
  } else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1163
    s4o.print("++");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1164
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1165
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1166
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1167
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1168
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1169
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1170
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1171
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1172
void *visit(while_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1173
  s4o.print("while (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1174
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1175
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1176
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1177
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1178
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1179
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1180
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1181
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1182
void *visit(repeat_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1183
  s4o.print("do {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1184
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1185
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1186
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1187
  s4o.print(s4o.indent_spaces); s4o.print("} while(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1188
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1189
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1190
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1191
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1192
void *visit(exit_statement_c *symbol) {
281
686fa44e3832 fixing exit_statement_c: produce 'break' instead of 'exit(0); (Thanks to Manuele)
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
  1193
  s4o.print("break");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1194
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1195
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1196
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1197
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1198
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1199
}; /* generate_c_st_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1200
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1201
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1202
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1203
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1204
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1205
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1206
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1207
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1208