stage4/generate_c/generate_c_st.cc
author laurent
Sun, 29 Nov 2009 16:38:11 +0100
changeset 217 f5dfadf5de54
parent 216 136d6ae70745
child 220 f332b62cd2c1
permissions -rwxr-xr-x
Adding support for declare, init, get and set macros
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     1
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     2
 * (c) 2003 Mario de Sousa
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     3
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     4
 * Offered to the public under the terms of the GNU General Public License
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     5
 * as published by the Free Software Foundation; either version 2 of the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     6
 * License, or (at your option) any later version.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     7
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     8
 * This program is distributed in the hope that it will be useful, but
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     9
 * WITHOUT ANY WARRANTY; without even the implied warranty of
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    10
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    11
 * Public License for more details.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    12
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    13
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    14
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    15
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    16
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    17
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    18
 * An IEC 61131-3 IL and ST compiler.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    19
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 * Based on the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * FINAL DRAFT - IEC 61131-3, 2nd Ed. (2001-12-10)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    23
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    24
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    25
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    26
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    27
 * Conversion of st statements (i.e. ST code).
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
 * This is part of the 4th stage that generates
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    30
 * a c++ source program equivalent to the IL and ST
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    31
 * code.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    32
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    33
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    34
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    35
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    36
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    37
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    38
/***********************************************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    39
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    40
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    41
class generate_c_st_c: public generate_c_typedecl_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    42
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    43
  public:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    44
    typedef enum {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    45
      expression_vg,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    46
      assignment_vg,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    47
      fparam_output_vg
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    48
    } variablegeneration_t;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    49
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    50
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    51
    /* When calling a function block, we must first find it's type,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    52
     * by searching through the declarations of the variables currently
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    53
     * in scope.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    54
     * This class does just that...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    55
     * A new class is instantiated whenever we begin generating the code
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    56
     * for a function block type declaration, or a program declaration.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    57
     * This object instance will then later be called while the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    58
     * function block's or the program's body is being handled.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    59
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    60
     * Note that functions cannot contain calls to function blocks,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
     * so we do not create an object instance when handling
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
     * a function declaration.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
    search_fb_instance_decl_c *search_fb_instance_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
    /* When compiling st code, it becomes necessary to determine the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
     * data type of st expressions. To do this, we must first find the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
     * st operand's declaration, within the scope of the function block
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
     * or function currently being processed.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
     * The following object does just that...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
     * This object instance will then later be called while the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
     * remaining st code is being handled.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
    search_expression_type_c *search_expression_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
    search_varfb_instance_type_c *search_varfb_instance_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    78
    search_base_type_c search_base_type;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    79
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    80
    symbol_c* current_array_type;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    81
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    82
    int fcall_number;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    83
    symbol_c *fbname;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    84
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    85
    variablegeneration_t wanted_variablegeneration;
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
    86
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
  public:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    88
    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
    89
    : generate_c_typedecl_c(s4o_ptr) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    90
      search_fb_instance_decl = new search_fb_instance_decl_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
      search_expression_type = new search_expression_type_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
      search_varfb_instance_type = new search_varfb_instance_type_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    93
      this->set_variable_prefix(variable_prefix);
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
    94
      current_array_type = NULL;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    95
      fcall_number = 0;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    96
      fbname = name;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
    97
      wanted_variablegeneration = expression_vg;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    99
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   100
    virtual ~generate_c_st_c(void) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   101
      delete search_fb_instance_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
      delete search_expression_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
      delete search_varfb_instance_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
    void generate(statement_list_c *stl) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   109
      stl->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   110
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   111
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   112
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
146
eef5e62048c7 Adding support for EN/ENO params in function and function blocks (standard function not supported yet)
lbessard
parents: 145
diff changeset
   114
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
/* B 1.4 - Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
void *visit(symbolic_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
  unsigned int vartype = search_varfb_instance_type->get_vartype(symbol);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   120
  if (this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   121
    if (wanted_variablegeneration == fparam_output_vg) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   122
      if (vartype == search_var_instance_decl_c::external_vt) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   123
    	s4o.print(GET_EXTERNAL);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   124
    	s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   125
    	symbol->var_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   126
      }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   127
      else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   128
    	s4o.print("&(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   129
        generate_c_base_c::visit(symbol);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   130
      }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   131
      s4o.print(")");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   132
    }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   133
    else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   134
      if (vartype == search_var_instance_decl_c::external_vt) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   135
        s4o.print(GET_EXTERNAL);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   136
        s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   137
        symbol->var_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   138
        s4o.print(")");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   139
      }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   140
      else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   141
    	generate_c_base_c::visit(symbol);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   142
    }
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   143
  }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
  else {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   145
    switch (wanted_variablegeneration) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   146
      case expression_vg:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   147
        if (vartype == search_var_instance_decl_c::external_vt) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   148
    	  s4o.print(GET_EXTERNAL);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   149
    	  s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   150
          symbol->var_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   151
        }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   152
        else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   153
          if (vartype == search_var_instance_decl_c::located_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   154
            s4o.print(GET_LOCATED);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   155
          else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   156
            s4o.print(GET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   157
          s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   158
          generate_c_base_c::visit(symbol);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   159
        }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   160
        s4o.print(")");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   161
		break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   162
      case fparam_output_vg:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   163
        if (vartype == search_var_instance_decl_c::external_vt) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   164
          s4o.print(GET_EXTERNAL_BY_REF);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   165
          s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   166
          symbol->var_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   167
        }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   168
        else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   169
          if (vartype == search_var_instance_decl_c::located_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   170
            s4o.print(GET_LOCATED_BY_REF);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   171
          else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   172
            s4o.print(GET_VAR_BY_REF);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   173
          s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   174
          generate_c_base_c::visit(symbol);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   175
        }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   176
        s4o.print(")");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   177
        break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   178
      default:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   179
        if (vartype == search_var_instance_decl_c::external_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   180
          symbol->var_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   181
        else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   182
          generate_c_base_c::visit(symbol);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   183
        break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   184
	}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   187
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   188
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
/* B.1.4.1   Directly Represented Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
// direct_variable: direct_variable_token   {$$ = new direct_variable_c($1);};
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
void *visit(direct_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
  TRACE("direct_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
  /* Do not use print_token() as it will change everything into uppercase */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
  if (strlen(symbol->value) == 0) ERROR;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   197
  if (this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   198
    if (wanted_variablegeneration != fparam_output_vg)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   199
	  s4o.print("*(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   200
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   201
  else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   202
    switch (wanted_variablegeneration) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   203
      case expression_vg:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   204
  	    s4o.print(GET_LOCATED);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   205
  	    s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   206
  	    break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   207
      case fparam_output_vg:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   208
        s4o.print(GET_LOCATED_BY_REF);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   209
        s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   210
        break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   211
      default:
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   212
        break;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   213
    }
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   214
  }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
  this->print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
  s4o.printlocation(symbol->value + 1);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   217
  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
   218
	  wanted_variablegeneration != assignment_vg)
145
72ae82e65dbc Adding support for ouput variables in functions
lbessard
parents: 130
diff changeset
   219
    s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   223
/*************************************/
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   224
/* B.1.4.2   Multi-element Variables */
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   225
/*************************************/
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   226
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   227
/*  subscripted_variable '[' subscript_list ']' */
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   228
//SYM_REF2(array_variable_c, subscripted_variable, subscript_list)
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   229
void *visit(array_variable_c *symbol) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   230
  current_array_type = search_varfb_instance_type->get_type(symbol->subscripted_variable, false);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   231
  symbol->subscripted_variable->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   232
  if (current_array_type != NULL) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   233
    symbol->subscript_list->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   234
    current_array_type = NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   235
  }
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   236
  return NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   237
}
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   238
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   239
/* subscript_list ',' subscript */
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   240
void *visit(subscript_list_c *symbol) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   241
  for (int i =  0; i < symbol->n; i++) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   242
    s4o.print("[__");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   243
    current_array_type->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   244
    s4o.print("_TRANSIDX");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   245
    print_integer(i);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   246
    s4o.print("(");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   247
    symbol->elements[i]->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   248
    s4o.print(")]");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   249
  }
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   250
  return NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   251
}
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   252
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   253
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   254
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   255
/* B.3 - Language ST (Structured Text) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   256
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   257
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   258
/* B 3.1 - Expressions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   259
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   260
void *visit(or_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   264
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
  if (search_expression_type->is_bool_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " || ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " | ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   271
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   272
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   273
void *visit(xor_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   274
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   275
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   276
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   277
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   278
  if (search_expression_type->is_bool_type(left_type)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   279
    s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   280
    symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   281
    s4o.print(" && !");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   282
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   283
    s4o.print(") || (!");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   284
    symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
    s4o.print(" && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
    s4o.print(")");
130
a8263f33123f Fixed missing return in XOR operator code gen.
etisserant
parents: 123
diff changeset
   288
    return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " ^ ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   293
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   294
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   296
void *visit(and_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   297
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   299
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   301
  if (search_expression_type->is_bool_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " & ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   307
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   308
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   309
void *visit(equ_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   310
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   311
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   312
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   314
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   315
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   316
    return print_compare_function("__eq_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   317
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " == ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   318
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   320
void *visit(notequ_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   321
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   322
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   323
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   324
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   325
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   326
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   327
    return print_compare_function("__ne_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   328
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " != ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   329
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   330
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   331
void *visit(lt_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   332
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   333
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   334
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   335
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   336
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   337
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   338
    return print_compare_function("__lt_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   339
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   340
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " < ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   341
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   342
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   343
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   344
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   345
void *visit(gt_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   346
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   347
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   348
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   349
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   350
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   351
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   352
    return print_compare_function("__gt_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   353
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   354
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " > ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   355
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   356
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   357
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   358
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   359
void *visit(le_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   360
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   361
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   362
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   363
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   364
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   365
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   366
    return print_compare_function("__le_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   367
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   368
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " <= ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   369
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   370
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   371
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   372
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   373
void *visit(ge_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   374
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   375
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   376
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   377
      ERROR;
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   378
  if (search_expression_type->is_time_type(left_type) ||
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   379
      search_expression_type->is_string_type(left_type))
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   380
    return print_compare_function("__ge_", left_type, symbol->l_exp, symbol->r_exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   381
  if (!search_base_type.type_is_enumerated(left_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   382
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " >= ");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   383
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   384
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   385
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   386
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   387
void *visit(add_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   388
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   389
	symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   390
	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
   391
      (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
   392
      (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
   393
    return print_binary_function("__TIME_ADD", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   394
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   395
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   396
  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
   397
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " + ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   399
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   400
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   401
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   402
void *visit(sub_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   403
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   405
  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
   406
      (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
   407
      (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
   408
      (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
   409
      (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
   410
      (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
   411
    return print_binary_function("__TIME_SUB", symbol->l_exp, symbol->r_exp);
70
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_integer_type(left_type) || search_expression_type->is_real_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
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
void *visit(mul_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
  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
   424
      (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
   425
    return print_binary_function("__TIME_MUL", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   426
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   427
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   428
  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
   429
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " * ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   434
void *visit(div_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   435
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   436
  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
   437
  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
   438
      (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
   439
    return print_binary_function("__TIME_DIV", symbol->l_exp, symbol->r_exp);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   440
  if (!search_expression_type->is_same_type(left_type, right_type))
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
  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
   443
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " / ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   444
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   445
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   446
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   447
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   448
void *visit(mod_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   449
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   450
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   452
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
  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
   454
    s4o.print("((");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   455
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   456
    s4o.print(" == 0)?0:");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   457
    print_binary_expression(symbol->l_exp, symbol->r_exp, " % ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   458
    s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   459
    return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   460
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   461
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   462
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   463
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   464
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
/* TODO: power expression... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
void *visit(power_expression_c *symbol) {ERROR; return print_binary_expression(symbol->l_exp, symbol->r_exp, " ** ");}
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   467
void *visit(neg_expression_c *symbol) {
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   468
  symbol_c *exp_type = search_expression_type->get_type(symbol->exp);
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   469
  if (search_expression_type->is_integer_type(exp_type) || search_expression_type->is_real_type(exp_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   470
    return print_unary_expression(symbol->exp, " -");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   471
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   472
  return NULL;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   473
}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   474
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   475
void *visit(not_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   476
  symbol_c *exp_type = search_expression_type->get_type(symbol->exp);
123
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   477
  if (search_expression_type->is_binary_type(exp_type))
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   478
    return print_unary_expression(symbol->exp, search_expression_type->is_bool_type(exp_type)?"!":"~");
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   479
  ERROR;
a9b4af71cfa4 Fixed some issues on:
lbessard
parents: 101
diff changeset
   480
  return NULL;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
void *visit(function_invocation_c *symbol) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   484
  symbol_c* function_type_prefix = NULL;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   485
  symbol_c* function_name = NULL;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   486
  symbol_c* function_type_suffix = NULL;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   487
  DECLARE_PARAM_LIST()
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   488
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   489
  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
   490
  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
   491
  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
   492
  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
   493
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   494
  function_declaration_c *f_decl = function_symtable.find_value(symbol->function_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
  if (f_decl == function_symtable.end_value()) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
    /* 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
   497
     * 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
   498
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
    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
   500
    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
   501
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
    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
   503
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
    function_call_param_iterator_c function_call_param_iterator(symbol);
167
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   505
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   506
    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
   507
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   508
    identifier_c en_param_name("EN");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   509
    /* Get the value from EN param */
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   510
    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
   511
    if (EN_param_value == NULL)
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   512
      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
   513
    else
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   514
      nb_param --;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   515
    ADD_PARAM_LIST(&en_param_name, EN_param_value, (symbol_c*)(new bool_type_name_c()), function_param_iterator_c::direction_in)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   516
162
60a124678842 Fixed typo in EN/ENO parameters handling for std library functions
etisserant
parents: 160
diff changeset
   517
    identifier_c eno_param_name("ENO");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   518
    /* Get the value from ENO param */
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   519
    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
   520
    if (ENO_param_value != NULL)
ae423926bc84 Fixed parameter count error on variadic functions with EN/ENO
etisserant
parents: 162
diff changeset
   521
      nb_param --;
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   522
    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
   523
146
eef5e62048c7 Adding support for EN/ENO params in function and function blocks (standard function not supported yet)
lbessard
parents: 145
diff changeset
   524
    #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
   525
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   527
  else {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   528
	function_name = symbol->function_name;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   529
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   530
	/* loop through each function parameter, find the value we should pass
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   531
     * to it, and then output the c equivalent...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   532
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   533
    function_param_iterator_c fp_iterator(f_decl);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   534
    identifier_c *param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   535
    function_call_param_iterator_c function_call_param_iterator(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   536
    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
   537
      
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   538
      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
   539
      
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   540
      /* 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
   541
      symbol_c *param_value = function_call_param_iterator.search_f(param_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   542
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   543
      /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   544
      if (param_value == NULL)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   545
        param_value = function_call_param_iterator.next_nf();
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   546
      
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   547
      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
   548
        /* 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
   549
        /* First check whether default value specified in function declaration...*/
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   550
        param_value = fp_iterator.default_value();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   551
      }
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   552
      
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   553
      symbol_c *param_type = fp_iterator.param_type();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   554
      if (param_type == NULL) ERROR;
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   555
      
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   556
      ADD_PARAM_LIST(param_name, param_value, param_type, param_direction)
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   557
    } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   558
    // symbol->parameter_assignment->accept(*this);
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   559
  }
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   560
  
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   561
  bool has_output_params = false;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   562
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   563
  if (!this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   564
    PARAM_LIST_ITERATOR() {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   565
	  if ((PARAM_DIRECTION == function_param_iterator_c::direction_out ||
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   566
		   PARAM_DIRECTION == function_param_iterator_c::direction_inout) &&
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   567
		  PARAM_VALUE != NULL) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   568
	    if (!has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   569
		  has_output_params = true;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   570
		}
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   571
	  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   572
    }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   573
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   574
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   575
  if (function_type_prefix != NULL) {
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   576
    s4o.print("(");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   577
    function_type_prefix->accept(*this);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   578
    s4o.print(")");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   579
  }
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   580
  if (has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   581
	fcall_number++;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   582
	s4o.print("__");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   583
    fbname->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   584
    s4o.print("_");
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   585
    function_name->accept(*this);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   586
    s4o.print_integer(fcall_number);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   587
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   588
  else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   589
    function_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   590
    if (function_type_suffix != NULL)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   591
      function_type_suffix->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   592
  }
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   593
  s4o.print("(");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   594
  s4o.indent_right();
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   595
  
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   596
  int nb_param = 0;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   597
  PARAM_LIST_ITERATOR() {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   598
    symbol_c *param_value = PARAM_VALUE;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   599
    symbol_c *param_type = PARAM_TYPE;
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   600
          
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   601
    switch (PARAM_DIRECTION) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   602
      case function_param_iterator_c::direction_in:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   603
    	if (nb_param > 0)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   604
    	  s4o.print(",\n"+s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   605
    	if (param_value == NULL) {
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   606
          /* If not, get the default value of this variable's type */
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   607
          param_value = (symbol_c *)param_type->accept(*type_initial_value_c::instance());
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   608
        }
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   609
        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
   610
        s4o.print("(");
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   611
        if (search_expression_type->is_literal_integer_type(param_type) ||
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   612
            search_expression_type->is_literal_real_type(param_type)) {
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   613
        	if (function_type_suffix == NULL) ERROR;
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   614
        	function_type_suffix->accept(*this);
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   615
        }
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   616
        else
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   617
        	param_type->accept(*this);
136d6ae70745 Bug with using non explicit literals as standard library functions input parameters fixed
laurent
parents: 208
diff changeset
   618
        s4o.print(")");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   619
        print_check_function(param_type, param_value);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   620
        nb_param++;
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   621
        break;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   622
      case function_param_iterator_c::direction_out:
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   623
      case function_param_iterator_c::direction_inout:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   624
    	if (!has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   625
          if (nb_param > 0)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   626
        	s4o.print(",\n"+s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   627
    	  if (param_value == NULL)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   628
            s4o.print("NULL");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   629
          else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   630
            wanted_variablegeneration = fparam_output_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   631
            param_value->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   632
            wanted_variablegeneration = expression_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   633
          }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   634
    	  nb_param++;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   635
    	}
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   636
        break;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   637
      case function_param_iterator_c::direction_extref:
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   638
        /* TODO! */
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   639
        ERROR;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   640
        break;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   641
    } /* switch */
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   642
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   643
  if (has_output_params) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   644
    if (nb_param > 0)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   645
      s4o.print(",\n"+s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   646
    s4o.print(FB_FUNCTION_PARAM);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   647
  }
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   648
  s4o.print(")");
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   649
  s4o.indent_left();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   650
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   651
  CLEAR_PARAM_LIST()
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   652
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   653
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   654
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   655
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   656
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   657
/* B 3.2 Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   658
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   659
void *visit(statement_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   660
  return print_list(symbol, s4o.indent_spaces, ";\n" + s4o.indent_spaces, ";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   661
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   662
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   663
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   664
/* B 3.2.1 Assignment Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   665
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   666
void *visit(assignment_statement_c *symbol) {
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   667
  symbol_c *left_type = search_varfb_instance_type->get_type(symbol->l_exp, false);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   668
  
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   669
  if (!this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   670
    unsigned int vartype = search_varfb_instance_type->get_vartype(symbol->l_exp);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   671
    if (vartype == search_var_instance_decl_c::external_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   672
	  s4o.print(SET_EXTERNAL);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   673
    else if (vartype == search_var_instance_decl_c::located_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   674
	  s4o.print(SET_LOCATED);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   675
    else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   676
	  s4o.print(SET_VAR);
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   677
    s4o.print("(");
217
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
    wanted_variablegeneration = assignment_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   680
    symbol->l_exp->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   681
    wanted_variablegeneration = expression_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   682
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   683
    s4o.print(",");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   684
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   685
  else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   686
	symbol->l_exp->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   687
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   688
    s4o.print(" = ");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   689
  }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   690
  print_check_function(left_type, symbol->r_exp);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   691
  if (!this->is_variable_prefix_null())
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   692
    s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   693
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   694
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   695
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   696
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   697
/* B 3.2.2 Subprogram Control Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   698
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   699
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   700
/* fb_name '(' [param_assignment_list] ')' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   701
/* param_assignment_list -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   702
//SYM_REF2(fb_invocation_c, fb_name, param_assignment_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   703
void *visit(fb_invocation_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   704
  TRACE("fb_invocation_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   705
  /* 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
   706
  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
   707
    /* should never occur. The function block instance MUST have been declared... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   708
  if (function_block_type_name == NULL) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   709
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   710
  /* Now find the declaration of the function block type being called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   711
  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
   712
    /* 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
   713
  if (fb_decl == function_block_type_symtable.end_value()) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   714
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   715
  /* loop through each function block parameter, find the value we should pass
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   716
   * to it, and then output the c equivalent...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   717
   */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   718
  function_param_iterator_c fp_iterator(fb_decl);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   719
  identifier_c *param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   720
  function_call_param_iterator_c function_call_param_iterator(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   721
  for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   722
    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
   723
    
162
60a124678842 Fixed typo in EN/ENO parameters handling for std library functions
etisserant
parents: 160
diff changeset
   724
    /*fprintf(stderr, "param : %s\n", param_name->value);*/
160
59d58f5e6caa Adding support for compiling struct data types
lbessard
parents: 149
diff changeset
   725
    
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   726
    /* 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
   727
    symbol_c *param_value = function_call_param_iterator.search_f(param_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   728
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   729
    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   730
    if (param_value == NULL)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   731
      param_value = function_call_param_iterator.next_nf();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   732
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   733
    symbol_c *param_type = fp_iterator.param_type();
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   734
    if (param_type == NULL) ERROR;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   735
    
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   736
    /* now output the value assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   737
    if (param_value != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   738
      if ((param_direction == function_param_iterator_c::direction_in) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   739
          (param_direction == function_param_iterator_c::direction_inout)) {
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   740
        if (!this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   741
          s4o.print(SET_VAR);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   742
          s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   743
        }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   744
    	print_variable_prefix();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   745
        symbol->fb_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   746
        s4o.print(".");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   747
        param_name->accept(*this);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   748
        if (this->is_variable_prefix_null())
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   749
          s4o.print(" = ");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   750
        else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   751
          s4o.print(",");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   752
        print_check_function(param_type, param_value);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   753
        if (!this->is_variable_prefix_null())
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   754
          s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   755
        s4o.print(";\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   756
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   757
  } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   758
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   759
  /* now call the function... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   760
  function_block_type_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   761
  s4o.print(FB_FUNCTION_SUFFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   762
  s4o.print("(&");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   763
  print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   764
  symbol->fb_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   765
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   766
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   767
  /* loop through each function parameter, find the variable to which
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   768
   * we should atribute the value of all output or inoutput parameters.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   769
   */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   770
  fp_iterator.reset();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   771
  function_call_param_iterator.reset();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   772
  for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   773
    function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   774
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   775
    /* 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
   776
    symbol_c *param_value = function_call_param_iterator.search_f(param_name);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   777
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   778
    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   779
    if (param_value == NULL)
202
da1a8186f86f Initial (very rough) version of semantic checker (stage3)
Catarina Boucinha <ccb@fe.up.pt>
parents: 169
diff changeset
   780
      param_value = function_call_param_iterator.next_nf();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   781
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   782
    /* now output the value assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   783
    if (param_value != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   784
      if ((param_direction == function_param_iterator_c::direction_out) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   785
          (param_direction == function_param_iterator_c::direction_inout)) {
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   786
        symbol_c *param_type = search_varfb_instance_type->get_type(param_value, false);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   787
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   788
        if (!this->is_variable_prefix_null()) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   789
          unsigned int vartype = search_varfb_instance_type->get_vartype(param_value);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   790
          s4o.print(";\n"+ s4o.indent_spaces);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   791
          if (vartype == search_var_instance_decl_c::external_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   792
            s4o.print(SET_EXTERNAL);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   793
          else if (vartype == search_var_instance_decl_c::located_vt)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   794
            s4o.print(SET_LOCATED);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   795
          else
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   796
            s4o.print(SET_VAR);
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   797
          s4o.print("(");
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
          wanted_variablegeneration = assignment_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   800
          param_value->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   801
          wanted_variablegeneration = expression_vg;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   802
          s4o.print(",");
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   803
        }
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   804
        else {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   805
          param_value->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   806
          s4o.print(" = ");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   807
        }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   808
        print_check_function(param_type, param_name, symbol->fb_name);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 216
diff changeset
   809
        if (!this->is_variable_prefix_null())
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   810
          s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   811
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   812
  } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   813
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   814
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   815
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   816
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
/* helper symbol for fb_invocation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   821
/* param_assignment_list ',' param_assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   822
void *visit(param_assignment_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   823
  TRACE("param_assignment_list_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   824
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   825
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   826
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   827
//  return print_list(symbol, "", ", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   828
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   829
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   830
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   831
void *visit(input_variable_param_assignment_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   832
  TRACE("input_variable_param_assignment_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   833
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   834
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   835
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   836
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   837
  symbol->variable_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   838
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   839
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   840
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   841
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   842
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   843
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   844
void *visit(output_variable_param_assignment_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   845
  TRACE("output_variable_param_assignment_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   846
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   847
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   848
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   849
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   850
  s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   851
  if (symbol->not_param != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   852
    symbol->not_param->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   853
  symbol->variable_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   854
  s4o.print(" => ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   855
  symbol->variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   856
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   857
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   858
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   859
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   860
// TODO: the NOT symbol in function (block) calls...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   861
void *visit(not_paramassign_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   862
  TRACE("not_paramassign_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   863
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   864
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   865
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   866
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   867
  s4o.print("NOT ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   868
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   869
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   870
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   871
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   872
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   873
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   874
/* B 3.2.3 Selection Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   875
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   876
void *visit(if_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   877
  s4o.print("if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   878
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   879
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   880
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   881
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   882
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   883
  symbol->elseif_statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   884
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   885
  if (symbol->else_statement_list != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   886
    s4o.print(s4o.indent_spaces); s4o.print("} else {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   887
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   888
    symbol->else_statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   889
    s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   890
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   891
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   892
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   893
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   894
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   895
/* helper symbol for if_statement */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   896
void *visit(elseif_statement_list_c *symbol) {return print_list(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   897
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   898
/* helper symbol for elseif_statement_list */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   899
void *visit(elseif_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   900
  s4o.print(s4o.indent_spaces); s4o.print("} else if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   901
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   902
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   903
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   904
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   905
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   906
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   907
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   908
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   909
void *visit(case_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   910
  s4o.print("switch(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   911
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   912
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   913
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   914
  symbol->case_element_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   915
  if (symbol->statement_list != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   916
    s4o.print(s4o.indent_spaces + "default:\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   917
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   918
    symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   919
    s4o.print(s4o.indent_spaces + "break;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   920
    s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   921
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   922
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   923
  s4o.print(s4o.indent_spaces + "}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   924
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   925
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   926
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   927
/* helper symbol for case_statement */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   928
void *visit(case_element_list_c *symbol) {return print_list(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   929
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   930
void *visit(case_element_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   931
  s4o.print(s4o.indent_spaces + "case ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   932
  symbol->case_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   933
  s4o.print(" :\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   934
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   935
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   936
  s4o.print(s4o.indent_spaces + "break;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   937
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   938
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   939
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   940
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   941
void *visit(case_list_c *symbol) {return print_list(symbol, "", ", ");}
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
/* B 3.2.4 Iteration Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   945
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   946
void *visit(for_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   947
  s4o.print("for(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   948
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   949
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   950
  symbol->beg_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   951
  s4o.print("; ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   952
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   953
  s4o.print(" != ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   954
  symbol->end_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   955
  s4o.print("; ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   956
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   957
  if (symbol->by_expression != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   958
    s4o.print(" += ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   959
    symbol->by_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   960
  } else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   961
    s4o.print("++");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   962
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   963
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   964
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   965
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   966
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   967
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   968
  return NULL;
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(while_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   971
  s4o.print("while (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   972
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   973
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   974
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   975
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   976
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   977
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   978
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   979
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   980
void *visit(repeat_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   981
  s4o.print("do {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   982
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   983
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   984
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   985
  s4o.print(s4o.indent_spaces); s4o.print("} while(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   986
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   987
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   988
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   989
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   990
void *visit(exit_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   991
  s4o.print("exit(0)");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   992
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   993
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   994
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
}; /* generate_c_st_c */
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1001
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1002
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1003
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1004
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1005
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1006