stage4/generate_c/generate_c_st.cc
author lbessard
Wed, 24 Oct 2007 17:39:51 +0200
changeset 70 e1f0ebd2d9ec
child 98 d0cdf1d00b74
permissions -rwxr-xr-x
Change generate_cc to generate_c
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    43
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    44
    /* When calling a function block, we must first find it's type,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    45
     * by searching through the declarations of the variables currently
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    46
     * in scope.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    47
     * This class does just that...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    48
     * A new class is instantiated whenever we begin generating the code
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    49
     * for a function block type declaration, or a program declaration.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    50
     * This object instance will then later be called while the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    51
     * function block's or the program's body is being handled.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    52
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    53
     * Note that functions cannot contain calls to function blocks,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    54
     * so we do not create an object instance when handling
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    55
     * a function declaration.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    56
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    57
    search_fb_instance_decl_c *search_fb_instance_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    58
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    59
    /* When compiling st code, it becomes necessary to determine the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    60
     * data type of st expressions. To do this, we must first find the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
     * st operand's declaration, within the scope of the function block
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
     * or function currently being processed.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
     * The following object does just that...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
     * This object instance will then later be called while the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
     * remaining st code is being handled.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
    search_expression_type_c *search_expression_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
    search_varfb_instance_type_c *search_varfb_instance_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
    generate_c_st_c(stage4out_c *s4o_ptr, symbol_c *scope, const char *variable_prefix = NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
    : generate_c_typedecl_c(s4o_ptr) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
      search_fb_instance_decl = new search_fb_instance_decl_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
      search_expression_type = new search_expression_type_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
      search_varfb_instance_type = new search_varfb_instance_type_c(scope);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
      this->set_variable_prefix(variable_prefix);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    78
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    79
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    80
    virtual ~generate_c_st_c(void) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    81
      delete search_fb_instance_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    82
      delete search_expression_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
      delete search_varfb_instance_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    86
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
    /* Some function calls in the body of functions or function blocks
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    89
     * may leave some parameters to their default values, and
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    90
     * ignore some output parameters of the function being called.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
     * Our conversion of ST functions to C++ does not contemplate that,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
     * i.e. each called function must get all it's input and output
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    93
     * parameters set correctly.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    94
     * For input parameters we merely need to call the function with
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    95
     * the apropriate default value, but for output parameters
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    96
     * we must create temporary variables to hold the output value.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    97
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
     * We declare all the temporary output variables at the begining of
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    99
     * the body of each function or function block, and use them as
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   100
     * in function calls later on as they become necessary...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   101
     * Note that we cannot create these variables just before a function
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
     * call, as the function call itself may be integrated within an
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
     * expression, or another function call!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
     * The variables are declared in the exact same order in which they
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
     * will be used later on during the function calls, which allows us
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
     * to simply re-create the name that was used for the temporary variable
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
     * instead of keeping it in some list.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   109
     * The names are recreated by the temp_var_name_factory, after reset()
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   110
     * has been called!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   111
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   112
     * This function will genertae code similar to...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
     *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   114
     *     INT __TMP_0 = 23;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
     *     REAL __TMP_1 = 45.5;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
     *     ...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
    temp_var_name_c temp_var_name_factory;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   120
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   121
    void generate(statement_list_c *stl) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   122
      generate_c_tempvardecl_c generate_c_tempvardecl(&s4o);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   123
      generate_c_tempvardecl.generate(stl, &temp_var_name_factory);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   124
      stl->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   125
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   126
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   128
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
/* B 1.4 - Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
void *visit(symbolic_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   133
  unsigned int vartype = search_varfb_instance_type->get_vartype(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   134
  if (vartype == search_var_instance_decl_c::external_vt || vartype == search_var_instance_decl_c::located_vt) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   135
    s4o.print("*(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   136
    generate_c_base_c::visit(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
    s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   138
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
  else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
    generate_c_base_c::visit(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   143
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   146
/* B.1.4.1   Directly Represented Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   147
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
// direct_variable: direct_variable_token   {$$ = new direct_variable_c($1);};
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
void *visit(direct_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   150
  TRACE("direct_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   151
  /* Do not use print_token() as it will change everything into uppercase */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   152
  if (strlen(symbol->value) == 0) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   153
  s4o.print("*(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   154
  this->print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
  s4o.printlocation(symbol->value + 1);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   156
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   157
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   158
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   159
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   160
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   161
/* B.3 - Language ST (Structured Text) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   163
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   164
/* B 3.1 - Expressions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   165
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   166
void *visit(or_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   167
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   168
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   169
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   170
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   171
  if (search_expression_type->is_bool_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " || ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   173
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " | ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   175
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   176
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   177
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   178
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   179
void *visit(xor_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
  if (search_expression_type->is_bool_type(left_type)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
    s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
    symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   187
    s4o.print(" && !");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   188
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
    s4o.print(") || (!");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
    symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
    s4o.print(" && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
    s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " ^ ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   197
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   199
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
void *visit(and_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   202
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   203
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   204
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   205
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   206
  if (search_expression_type->is_bool_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   207
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
  if (search_expression_type->is_binary_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " & ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   210
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   211
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   212
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   213
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
void *visit(equ_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   218
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
  if (search_expression_type->is_time_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
    return print_compare_function("__eq_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " == ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
void *visit(notequ_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   226
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   227
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   228
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   229
  if (search_expression_type->is_time_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   230
    return print_compare_function("__ne_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   231
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " != ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   232
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   233
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   234
void *visit(lt_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   235
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   236
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   237
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   238
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   239
  if (search_expression_type->is_time_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   240
    return print_compare_function("__lt_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   241
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " < ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   242
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   243
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   244
void *visit(gt_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   245
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   246
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   247
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   248
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   249
  if (search_expression_type->is_time_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   250
    return print_compare_function("__gt_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   251
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " > ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   252
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   253
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   254
void *visit(le_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   255
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   256
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   257
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   258
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   259
  if (search_expression_type->is_time_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   260
    return print_compare_function("__le_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " <= ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   264
void *visit(ge_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
  if (search_expression_type->is_time_type(left_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
    return print_compare_function("__ge_", left_type, symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   271
  return print_binary_expression(symbol->l_exp, symbol->r_exp, " >= ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   272
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   273
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   274
void *visit(add_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   275
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   276
	symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   277
	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
   278
      (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
   279
      (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
   280
    return print_binary_function("__time_add", symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   281
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   282
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   283
  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
   284
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " + ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   288
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
void *visit(sub_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
  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
   293
      (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
   294
      (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
   295
      (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
   296
      (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
   297
      (typeid(*left_type) == typeid(dt_type_name_c) && typeid(*right_type) == typeid(dt_type_name_c)))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
    return print_binary_function("__time_sub", symbol->l_exp, 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_integer_type(left_type) || search_expression_type->is_real_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
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   307
void *visit(mul_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   308
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   309
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   310
  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
   311
      (typeid(*left_type) == typeid(time_type_name_c) && search_expression_type->is_real_type(right_type)))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   312
    return print_binary_function("__time_mul", symbol->l_exp, symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   314
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   315
  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
   316
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " * ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   317
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   318
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   320
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   321
void *visit(div_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   322
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   323
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   324
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   325
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   326
  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
   327
    return print_binary_expression(symbol->l_exp, symbol->r_exp, " / ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   328
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   329
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   330
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   331
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   332
void *visit(mod_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   333
  symbol_c *left_type = search_expression_type->get_type(symbol->l_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   334
  symbol_c *right_type = search_expression_type->get_type(symbol->r_exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   335
  if (!search_expression_type->is_same_type(left_type, right_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   336
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   337
  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
   338
    s4o.print("((");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   339
    symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   340
    s4o.print(" == 0)?0:");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   341
    print_binary_expression(symbol->l_exp, symbol->r_exp, " % ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   342
    s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   343
    return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   344
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   345
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   346
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   347
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   348
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   349
/* TODO: power expression... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   350
void *visit(power_expression_c *symbol) {ERROR; return print_binary_expression(symbol->l_exp, symbol->r_exp, " ** ");}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   351
void *visit(neg_expression_c *symbol) {return print_unary_expression(symbol->exp, " -");}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   352
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   353
void *visit(not_expression_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   354
  symbol_c *exp_type = search_expression_type->get_type(symbol->exp);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   355
  if (!search_expression_type->is_binary_type(exp_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   356
     ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   357
  return print_unary_expression(symbol->exp, search_expression_type->is_bool_type(exp_type)?"!":"~");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   358
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   359
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   360
void *visit(function_invocation_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   361
  function_declaration_c *f_decl = function_symtable.find_value(symbol->function_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   362
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   363
  if (f_decl == function_symtable.end_value()) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   364
    /* 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
   365
     * standard function defined in standard */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   366
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   367
    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
   368
    if (current_function_type == function_none) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   369
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   370
    symbol_c *function_return_type = search_expression_type->get_type(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   371
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   372
    function_call_param_iterator_c function_call_param_iterator(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   373
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   374
    int nb_param = ((list_c *)symbol->parameter_assignment_list)->n;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   375
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   376
#include "st_code_gen.c"
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   377
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   378
#if 0
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   379
    for(int current_param = 0; current_param < nb_param; current_param++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   380
      symbol_c *param_name = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   381
      switch (current_function_type) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   382
        case function_add:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   383
        case function_and:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   384
        case function_or:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   385
          param_name = generate_param_name("IN%d", current_param + 1);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   386
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   387
        case function_sub:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   388
          if (current_param < 2)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   389
            param_name = generate_param_name("IN%d", current_param + 1);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   390
          else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   391
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   392
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   393
        default: ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   394
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   395
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   396
      /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   397
      symbol_c *param_value = function_call_param_iterator.search(param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
      delete param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   399
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   400
      /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   401
      if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   402
        param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   403
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
      if (param_value == NULL) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   405
      
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
      switch (current_function_type) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
        case function_add:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
          if (search_expression_type->is_time_type(function_return_type)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
            if (current_param == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   410
              s4o.print("__time_add(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   411
              param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   412
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
            else if (current_param == 1) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   414
              s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   415
              param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
              s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
            else ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
          else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
            if (current_param == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
              s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
            else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   424
              s4o.print(" + ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   425
            param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   426
            if (current_param == nb_param - 1)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   427
              s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   428
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   429
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
        case function_sub:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
          if (search_expression_type->is_time_type(function_return_type)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
            if (current_param == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
              s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   434
              param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   435
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   436
            else if (current_param == 1) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   437
              s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
              param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   439
              s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   440
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   441
            else ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   442
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   443
          else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   444
            if (current_param == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   445
              s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   446
              param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   447
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   448
            else if (current_param == 1) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   449
              s4o.print(" - ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   450
              param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
              s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   452
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
            else ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   454
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   455
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   456
        case function_and:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   457
          if (current_param == 0)
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
          else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   460
            if (search_expression_type->is_bool_type(function_return_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   461
              s4o.print(" && ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   462
            else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   463
              s4o.print(" & ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   464
          param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
          if (current_param == nb_param - 1)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
            s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   467
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   468
        case function_or:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   469
          if (current_param == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   470
            s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   471
          else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   472
            if (search_expression_type->is_bool_type(function_return_type))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   473
              s4o.print(" || ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   474
            else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   475
              s4o.print(" | ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   476
          param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   477
          if (current_param == nb_param - 1)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   478
            s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   479
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   480
        default: ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
    } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
#endif
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   484
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   485
  else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   486
    /* loop through each function parameter, find the value we should pass
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
     * to it, and then output the c equivalent...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   488
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   489
    function_param_iterator_c fp_iterator(f_decl);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   490
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   491
    symbol->function_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
    s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   494
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
    identifier_c *param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
    function_call_param_iterator_c function_call_param_iterator(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   497
    for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
      if (i != 1)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
        s4o.print(",\n"+s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   500
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
      function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   503
      /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
      symbol_c *param_value = function_call_param_iterator.search(param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   505
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   506
      /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   507
      if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   508
        param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   509
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   510
      symbol_c *param_type = fp_iterator.param_type();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   511
      if (param_type == NULL) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   512
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   513
      switch (param_direction) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   514
        case function_param_iterator_c::direction_in:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   515
          if (param_value == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   516
            /* No value given for parameter, so we must use the default... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   517
            /* First check whether default value specified in function declaration...*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   518
            param_value = fp_iterator.default_value();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   519
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   520
          if (param_value == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   521
            /* If not, get the default value of this variable's type */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   522
            param_value = (symbol_c *)param_type->accept(*type_initial_value_c::instance());
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   523
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   524
          if (param_value == NULL) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   525
          param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   527
        case function_param_iterator_c::direction_out:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   528
        case function_param_iterator_c::direction_inout:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   529
          if (param_value == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   530
            /* no parameter value given, so we pass a previously declared temporary variable. */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   531
            std::string *temp_var_name = temp_var_name_factory.new_name();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   532
            s4o.print(*temp_var_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   533
            delete temp_var_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   534
          } else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   535
            param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   536
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   537
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   538
        case function_param_iterator_c::direction_extref:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   539
          /* TODO! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   540
          ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   541
          break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   542
      } /* switch */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   543
    } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   544
    // symbol->parameter_assignment->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   545
    s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   546
    s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   547
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   548
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   549
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   550
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   551
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   552
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   553
/* B 3.2 Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   554
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   555
void *visit(statement_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   556
  return print_list(symbol, s4o.indent_spaces, ";\n" + s4o.indent_spaces, ";\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   557
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   558
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   559
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   560
/* B 3.2.1 Assignment Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   561
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   562
void *visit(assignment_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   563
  symbol->l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   564
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   565
  symbol->r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   566
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   567
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   568
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   569
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   570
/* B 3.2.2 Subprogram Control Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   571
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   572
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   573
/* fb_name '(' [param_assignment_list] ')' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   574
/* param_assignment_list -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   575
//SYM_REF2(fb_invocation_c, fb_name, param_assignment_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   576
void *visit(fb_invocation_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   577
  TRACE("fb_invocation_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   578
  /* 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
   579
  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
   580
    /* should never occur. The function block instance MUST have been declared... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   581
  if (function_block_type_name == NULL) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   582
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   583
  /* Now find the declaration of the function block type being called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   584
  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
   585
    /* 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
   586
  if (fb_decl == function_block_type_symtable.end_value()) ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   587
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   588
  /* loop through each function block parameter, find the value we should pass
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   589
   * to it, and then output the c equivalent...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   590
   */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   591
  function_param_iterator_c fp_iterator(fb_decl);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   592
  identifier_c *param_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   593
  function_call_param_iterator_c function_call_param_iterator(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   594
  for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   595
    function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   596
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   597
    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   598
    symbol_c *param_value = function_call_param_iterator.search(param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   599
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   600
    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   601
    if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   602
      param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   603
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   604
    /* now output the value assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   605
    if (param_value != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   606
      if ((param_direction == function_param_iterator_c::direction_in) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   607
          (param_direction == function_param_iterator_c::direction_inout)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   608
        print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   609
        symbol->fb_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   610
        s4o.print(".");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   611
        param_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   612
        s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   613
        param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   614
        s4o.print(";\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   615
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   616
  } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   617
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   618
  /* now call the function... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   619
  function_block_type_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   620
  s4o.print(FB_FUNCTION_SUFFIX);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   621
  s4o.print("(&");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   622
  print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   623
  symbol->fb_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   624
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   625
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   626
  /* loop through each function parameter, find the variable to which
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   627
   * we should atribute the value of all output or inoutput parameters.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   628
   */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   629
  fp_iterator.reset();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   630
  function_call_param_iterator.reset();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   631
  for(int i = 1; (param_name = fp_iterator.next()) != NULL; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   632
    function_param_iterator_c::param_direction_t param_direction = fp_iterator.param_direction();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   633
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   634
    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   635
    symbol_c *param_value = function_call_param_iterator.search(param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   636
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   637
    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   638
    if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   639
      param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   640
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   641
    /* now output the value assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   642
    if (param_value != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   643
      if ((param_direction == function_param_iterator_c::direction_out) ||
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   644
          (param_direction == function_param_iterator_c::direction_inout)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   645
        s4o.print(";\n"+ s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   646
        param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   647
        s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   648
        print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   649
        symbol->fb_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   650
        s4o.print(".");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   651
        param_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   652
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   653
  } /* for(...) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   654
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   655
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   656
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   657
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   658
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   659
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   660
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   661
/* helper symbol for fb_invocation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   662
/* param_assignment_list ',' param_assignment */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   663
void *visit(param_assignment_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   664
  TRACE("param_assignment_list_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   665
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   666
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   667
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   668
//  return print_list(symbol, "", ", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   669
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   670
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   671
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   672
void *visit(input_variable_param_assignment_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   673
  TRACE("input_variable_param_assignment_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   674
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   675
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   676
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   677
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   678
  symbol->variable_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   679
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   680
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   681
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   682
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   683
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   684
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   685
void *visit(output_variable_param_assignment_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   686
  TRACE("output_variable_param_assignment_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   687
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   688
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   689
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   690
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   691
  s4o.print(s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   692
  if (symbol->not_param != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   693
    symbol->not_param->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   694
  symbol->variable_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   695
  s4o.print(" => ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   696
  symbol->variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   697
  return NULL;
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   701
// TODO: the NOT symbol in function (block) calls...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   702
void *visit(not_paramassign_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   703
  TRACE("not_paramassign_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   704
  /* this should never be called... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   705
  ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   706
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   707
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   708
  s4o.print("NOT ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   709
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   710
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   711
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   712
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   713
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   714
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   715
/* B 3.2.3 Selection Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   716
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   717
void *visit(if_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   718
  s4o.print("if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   719
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   720
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   721
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   722
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   723
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   724
  symbol->elseif_statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   725
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   726
  if (symbol->else_statement_list != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   727
    s4o.print(s4o.indent_spaces); s4o.print("} else {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   728
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   729
    symbol->else_statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   730
    s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   731
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   732
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   733
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   734
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   735
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   736
/* helper symbol for if_statement */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   737
void *visit(elseif_statement_list_c *symbol) {return print_list(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   738
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   739
/* helper symbol for elseif_statement_list */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   740
void *visit(elseif_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   741
  s4o.print(s4o.indent_spaces); s4o.print("} else if (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   742
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   743
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   744
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   745
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   746
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   747
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   748
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   749
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   750
void *visit(case_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   751
  s4o.print("switch(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   752
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   753
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   754
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   755
  symbol->case_element_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   756
  if (symbol->statement_list != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   757
    s4o.print(s4o.indent_spaces + "default:\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   758
    s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   759
    symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   760
    s4o.print(s4o.indent_spaces + "break;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   761
    s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   762
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   763
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   764
  s4o.print(s4o.indent_spaces + "}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   765
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   766
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   767
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   768
/* helper symbol for case_statement */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   769
void *visit(case_element_list_c *symbol) {return print_list(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   770
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   771
void *visit(case_element_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   772
  s4o.print(s4o.indent_spaces + "case ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   773
  symbol->case_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   774
  s4o.print(" :\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   775
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   776
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   777
  s4o.print(s4o.indent_spaces + "break;\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   778
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   779
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   780
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   781
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   782
void *visit(case_list_c *symbol) {return print_list(symbol, "", ", ");}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   783
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   784
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   785
/* B 3.2.4 Iteration Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   786
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   787
void *visit(for_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   788
  s4o.print("for(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   789
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   790
  s4o.print(" = ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   791
  symbol->beg_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   792
  s4o.print("; ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   793
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   794
  s4o.print(" != ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   795
  symbol->end_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   796
  s4o.print("; ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   797
  symbol->control_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   798
  if (symbol->by_expression != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   799
    s4o.print(" += ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   800
    symbol->by_expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   801
  } else {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   802
    s4o.print("++");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   803
  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   804
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   805
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   806
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   807
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   808
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   809
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   810
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   811
void *visit(while_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   812
  s4o.print("while (");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   813
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   814
  s4o.print(") {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   815
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   816
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   817
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   818
  s4o.print(s4o.indent_spaces); s4o.print("}");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   819
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   820
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   821
void *visit(repeat_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   822
  s4o.print("do {\n");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   823
  s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   824
  symbol->statement_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   825
  s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   826
  s4o.print(s4o.indent_spaces); s4o.print("} while(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   827
  symbol->expression->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   828
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   829
  return NULL;
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(exit_statement_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   832
  s4o.print("exit(0)");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   833
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   834
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   835
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   836
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   837
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   838
}; /* generate_c_st_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   839
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   840
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   845
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   846
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   847