stage4/generate_c/generate_c_base.cc
author Mario de Sousa <msousa@fe.up.pt>
Sun, 22 Dec 2013 09:50:02 +0000
changeset 854 13d0b67de111
parent 793 268bf4ca5fa1
child 860 7669a8d43c11
permissions -rw-r--r--
Code cleanup: move datatype analysis to get_datatype_info_c
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     1
/*
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
     2
 *  matiec - a compiler for the programming languages defined in IEC 61131-3
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     3
 *
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
     4
 *  Copyright (C) 2003-2011  Mario de Sousa (msousa@fe.up.pt)
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
     5
 *  Copyright (C) 2007-2011  Laurent Bessard and Edouard Tisserant
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     6
 *
279
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
     7
 *  This program is free software: you can redistribute it and/or modify
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
     8
 *  it under the terms of the GNU General Public License as published by
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
     9
 *  the Free Software Foundation, either version 3 of the License, or
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    10
 *  (at your option) any later version.
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    11
 *
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    12
 *  This program is distributed in the hope that it will be useful,
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    13
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    14
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    15
 *  GNU General Public License for more details.
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    16
 *
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    17
 *  You should have received a copy of the GNU General Public License
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    18
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
c0453b7f99df Re-generated std lib related code, with updated headers, updated all forgotten headers
Edouard Tisserant
parents: 267
diff changeset
    19
 *
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    23
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    24
139
668a54686827 added missing includes on some platform (gentoo/gcc-4.3.1)
etisserant
parents: 118
diff changeset
    25
#include <string.h>
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    26
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    27
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    30
typedef struct
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    31
{
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    32
  symbol_c *param_name;
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    33
  symbol_c *param_value;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    34
  symbol_c *param_type;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    35
  function_param_iterator_c::param_direction_t param_direction;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    36
} FUNCTION_PARAM;
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    37
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    38
#define DECLARE_PARAM_LIST()\
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    39
  std::list<FUNCTION_PARAM*> param_list;\
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    40
  std::list<FUNCTION_PARAM*>::iterator pt;\
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    41
  FUNCTION_PARAM *param;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    42
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    43
#define ADD_PARAM_LIST(name, value, type, direction)\
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    44
  param = new FUNCTION_PARAM;\
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    45
  param->param_name = name;\
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    46
  param->param_value = value;\
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    47
  param->param_type = type;\
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
    48
  param->param_direction = direction;\
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    49
  param_list.push_back(param);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    50
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    51
#define PARAM_LIST_ITERATOR() for(pt = param_list.begin(); pt != param_list.end(); pt++)
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    52
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    53
#define PARAM_NAME (*pt)->param_name
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    54
#define PARAM_VALUE (*pt)->param_value
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    55
#define PARAM_TYPE (*pt)->param_type
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    56
#define PARAM_DIRECTION (*pt)->param_direction
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    57
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    58
#define CLEAR_PARAM_LIST()\
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    59
  PARAM_LIST_ITERATOR()\
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    60
    delete *pt;\
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    61
  param_list.clear();
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
class generate_c_base_c: public iterator_visitor_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
  protected:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
    stage4out_c &s4o;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
    /* Unlike programs that are mapped onto C++ classes, Function Blocks are mapped onto a data structure type
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    71
     * and a separate function containing the code. This function is passed a pointer to an instance of the data
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
     * structure. This means that the code inside the functions must insert a pointer to the data structure whenever
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
     * it wishes to access a Function Block variable.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
     * The variable_prefix_ variable will contain the correct string which needs to be prefixed to all variable accesses.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
     * This string is set with the set_variable_prefix() member function.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
     */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
    const char *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
  public:
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    80
    generate_c_base_c(stage4out_c *s4o_ptr): s4o(*s4o_ptr) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    81
      variable_prefix_ = NULL;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
    82
    }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
    ~generate_c_base_c(void) {}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
    void set_variable_prefix(const char *variable_prefix) {variable_prefix_ = variable_prefix;}
160
59d58f5e6caa Adding support for compiling struct data types
lbessard
parents: 149
diff changeset
    86
    const char *get_variable_prefix(void) {return variable_prefix_;}
146
eef5e62048c7 Adding support for EN/ENO params in function and function blocks (standard function not supported yet)
lbessard
parents: 139
diff changeset
    87
    bool is_variable_prefix_null(void) {return variable_prefix_ == NULL;}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
    void print_variable_prefix(void) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    89
      if (variable_prefix_ != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    90
        s4o.print(variable_prefix_);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    93
    void *print_token(token_c *token, int offset = 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    94
      return s4o.printupper((token->value)+offset);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    95
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    96
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    97
    void *print_literal(symbol_c *type, symbol_c *value) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
      s4o.print("__");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    99
      type->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   100
      s4o.print("_LITERAL(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   101
      value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
    void *print_striped_token(token_c *token, int offset = 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
      std::string str = "";
312
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   108
      bool leading_zero = true;
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   109
      for (unsigned int i = offset; i < strlen(token->value); i++) {
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   110
        if (leading_zero &&
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   111
        	(token->value[i] != '0' ||
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   112
        	 i == strlen(token->value) - 1 ||
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   113
        	 token->value[i + 1] == '.'
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   114
        	))
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   115
          leading_zero = false;
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   116
    	if (!leading_zero && token->value[i] != '_')
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
          str += token->value[i];
312
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   118
      }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
      return s4o.printupper(str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   120
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   121
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   122
    void *print_striped_binary_token(token_c *token, unsigned int offset = 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   123
      /* convert the binary value to hexadecimal format... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   124
      unsigned char value, bit_mult;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   125
      unsigned int i;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   126
      int total_bits;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
      char str[2] = {'A', '\0'};  /* since the s4o object is not prepared to print out one character at a time... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   128
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
      s4o.print("0x");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
      total_bits = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
      for (i = offset; i < strlen(token->value); i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   133
        if (token->value[i] != '_')
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   134
	  total_bits++;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   135
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   136
      value = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
      bit_mult = (unsigned char)1 << (((total_bits+3)%4)+1);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   138
      for (i = offset; i < strlen(token->value); i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
        if (token->value[i] != '_') {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
	  bit_mult /= 2;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
	  value += bit_mult * ((token->value[i] == '0')? 0:1);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
	  if (bit_mult == 1) {
308
833cb2eba36f Fix conversion of binary digits to hex, when generating code.
Mario de Sousa <msousa@fe.up.pt>
parents: 279
diff changeset
   143
	    str[0] = (value <= 9)? (char)'0' + value : (char)'A' + value - 10;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
	    s4o.print(str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
            bit_mult = 0x10;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   146
            value = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   147
	  }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
	}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   150
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   151
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   152
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   153
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   154
    void *print_list(list_c *list,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
		     std::string pre_elem_str = "",
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   156
		     std::string inter_elem_str = "",
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   157
		     std::string post_elem_str = "",
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   158
		     visitor_c *visitor = NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   159
      if (visitor == NULL) visitor = this;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   160
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   161
      if (list->n > 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
//std::cout << "generate_c_base_c::print_list(n = " << list->n << ")   000\n";
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   163
        s4o.print(pre_elem_str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   164
        list->elements[0]->accept(*visitor);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   165
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   166
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   167
      for(int i = 1; i < list->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   168
//std::cout << "generate_c_base_c::print_list   " << i << "\n";
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   169
        s4o.print(inter_elem_str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   170
        list->elements[i]->accept(*visitor);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   171
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   173
      if (list->n > 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
        s4o.print(post_elem_str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   175
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
    void *print_binary_expression(symbol_c *l_exp,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
				  symbol_c *r_exp,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
				  const char *operation) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
      s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
      l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
      s4o.print(operation);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
      r_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
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
    void *print_unary_expression(symbol_c *exp,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
				 const char *operation) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
      s4o.print(operation);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
      s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
      exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   197
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   199
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
    void *print_binary_function(const char *function,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
          symbol_c *l_exp,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   202
				  symbol_c *r_exp) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   203
      s4o.print(function);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   204
      s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   205
      l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   206
      s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   207
      r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   210
   	}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   211
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   212
    void *print_compare_function(const char *function,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   213
          symbol_c *compare_type,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
          symbol_c *l_exp,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
          symbol_c *r_exp) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
      s4o.print(function);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
      compare_type->accept(*this);
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   218
      s4o.print("(__BOOL_LITERAL(TRUE), NULL, 2, ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
      l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
      s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
      r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   226
    void *print_check_function(symbol_c *type,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   227
          symbol_c *value,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   228
          symbol_c *fb_name = NULL,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   229
          bool temp = false) {
854
13d0b67de111 Code cleanup: move datatype analysis to get_datatype_info_c
Mario de Sousa <msousa@fe.up.pt>
parents: 793
diff changeset
   230
      if (!get_datatype_info_c::is_type_valid(type)) ERROR;
13d0b67de111 Code cleanup: move datatype analysis to get_datatype_info_c
Mario de Sousa <msousa@fe.up.pt>
parents: 793
diff changeset
   231
      bool is_subrange = get_datatype_info_c::is_subrange(type);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   232
      if (is_subrange) {
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   233
		s4o.print("__CHECK_");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   234
		type->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   235
		s4o.print("(");
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   236
      }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   237
      if (fb_name != NULL) {
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   238
        s4o.print(GET_VAR);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   239
        s4o.print("(");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   240
        print_variable_prefix();
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   241
        fb_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   242
        s4o.print(".");
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   243
        value->accept(*this);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   244
        s4o.print(")");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   245
      }
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   246
      else {
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   247
        if (temp)
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   248
    	  s4o.print(TEMP_VAR);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   249
        value->accept(*this);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   250
      }
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   251
      if (is_subrange)
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   252
        s4o.print(")");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   253
      return NULL;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   254
    }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   255
267
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   256
/********************/
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   257
/* 2.1.6 - Pragmas  */
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   258
/********************/
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   259
    void *visit(enable_code_generation_pragma_c * symbol)   {s4o.enable_output();  return NULL;}
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   260
    void *visit(disable_code_generation_pragma_c * symbol)  {s4o.disable_output(); return NULL;} 
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   261
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
    /* Do not use print_token() as it will change everything into uppercase */
634
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   263
    void *visit(pragma_c *symbol) {
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   264
        s4o.print(s4o.indent_spaces);
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   265
        s4o.print("#define GetFbVar(var,...) __GET_VAR(data__->var,__VA_ARGS__)\n");
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   266
        s4o.print(s4o.indent_spaces);
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   267
        s4o.print("#define SetFbVar(var,val,...) __SET_VAR(data__->,var,val,__VA_ARGS__)\n");
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   268
        s4o.print(symbol->value);
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   269
        s4o.print("\n");
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   270
        s4o.print(s4o.indent_spaces);
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   271
        s4o.print("#undef GetFbVar\n");
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   272
        s4o.print(s4o.indent_spaces);
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   273
        s4o.print("#undef SetFbVar\n");
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   274
        return NULL;
736b36a83548 Added double curly braces for pragma (kept single curly braces for compatibility). Added macro def and undef surrounding pragma to simplify user code. Moved useless comment from generated code back to code generator.
Edouard Tisserant
parents: 594
diff changeset
   275
    }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   276
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   277
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   278
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   279
/* B 0 - Programming Model */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   280
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   281
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   282
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   283
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   284
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
/*************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
/* B.1 - Common elements */
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
/* B 1.1 - Letters, digits and identifiers */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
/*******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
    void *visit(identifier_c *symbol) {return print_token(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   293
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   294
/* B 1.2 - Constants */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   296
  /* originally empty... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   297
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
/******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   299
/* B 1.2.1 - Numeric Literals */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
/******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   301
    void *visit(real_c *symbol) {return print_striped_token(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
    void *visit(integer_c *symbol) {return print_striped_token(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
    void *visit(binary_integer_c *symbol) {return print_striped_binary_token(symbol, 2);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
    void *visit(octal_integer_c *symbol) {s4o.print("0"); return print_striped_token(symbol, 2);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
    void *visit(hex_integer_c *symbol) {s4o.print("0x"); return print_striped_token(symbol, 3);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   307
    void *visit(neg_real_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   308
      s4o.print("-");
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   309
      symbol->exp->accept(*this);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   310
      return NULL;
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   311
    }
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   312
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   313
    void *visit(neg_integer_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   314
      s4o.print("-");
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   315
      symbol->exp->accept(*this);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   316
      return NULL;
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   317
    }
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   318
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
    void *visit(integer_literal_c *symbol) {return print_literal(symbol->type, symbol->value);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   320
    void *visit(real_literal_c *symbol) {return print_literal(symbol->type, symbol->value);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   321
    void *visit(bit_string_literal_c *symbol) {return print_literal(symbol->type, symbol->value);}
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   322
    void *visit(boolean_literal_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   323
      if (NULL != symbol->type)
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   324
        return print_literal(symbol->type, symbol->value);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   325
      else {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   326
	bool_type_name_c bool_type;
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   327
	return print_literal(&bool_type, symbol->value);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   328
      }
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   329
    }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   330
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   331
    /* helper class for boolean_literal_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   332
    void *visit(boolean_true_c *symbol) {s4o.print("TRUE"); return NULL;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   333
    void *visit(boolean_false_c *symbol) {s4o.print("FALSE"); return NULL;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   334
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   335
    void *visit(neg_expression_c *symbol) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   336
      s4o.print("-");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   337
      symbol->exp->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   338
      return NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   339
    }
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   340
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   341
/*******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   342
/* B.1.2.2   Character Strings */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   343
/*******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   344
    void *visit(double_byte_character_string_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   345
      // TO DO ...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   346
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   347
      return print_token(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   348
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   349
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   350
    void *visit(single_byte_character_string_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   351
      std::string str = "";
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   352
      unsigned int count = 0; 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   353
      str += '"';
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   354
      /* we ignore the first and last bytes, they will be the character ' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   355
      for (unsigned int i = 1; i < strlen(symbol->value) - 1; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   356
        char c = symbol->value[i];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   357
        if ((c == '\\') || (c == '"'))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   358
          {str += '\\'; str += c; count ++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   359
        if (c != '$')
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   360
          {str += c; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   361
        /* this should be safe, since the code has passed the syntax parser!! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   362
        c = symbol->value[++i];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   363
        switch (c) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   364
          case '$':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   365
          case '\'':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   366
            {str += c; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   367
          case 'L':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   368
          case 'l':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   369
            {str += "\x0A"; /* LF */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   370
          case 'N':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   371
          case 'n':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   372
            {str += "\\x0A"; /* NL */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   373
          case 'P':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   374
          case 'p':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   375
            {str += "\\f"; /* FF */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   376
          case 'R':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   377
          case 'r':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   378
            {str += "\\r"; /* CR */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   379
          case 'T':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   380
          case 't':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   381
            {str += "\\t"; /* tab */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   382
          default: {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   383
            if (isxdigit(c)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   384
              /* this should be safe, since the code has passed the syntax parser!! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   385
	      char c2 = symbol->value[++i];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   386
	      if (isxdigit(c2)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   387
	        str += '\\'; str += 'x'; str += c; str += c2;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   388
	        count++; continue;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   389
	      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   390
	    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   391
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   392
          /* otherwise we have an invalid string!! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   393
          /* This should not have got through the syntax parser! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   394
          ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   395
        } /* switch() */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   396
      } /* for() */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   397
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
      str += '"';
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   399
      s4o.print("__STRING_LITERAL(");
594
c8092e909886 Clean up code (remove parsing of integers in stage 4).
Mario de Sousa <msousa@fe.up.pt>
parents: 547
diff changeset
   400
      s4o.print(count); 
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   401
      s4o.print(",");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   402
      s4o.print(str);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   403
      s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   405
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
/* B 1.2.3 - Time Literals */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   410
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   411
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   412
/************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
/* B 1.2.3.1 - Duration */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   414
/************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   415
/* The following output is actually the parameters to the constructor of the TIME class! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
/* SYM_REF0(neg_time_c) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
void *visit(neg_time_c *symbol) {s4o.print("-1"); /* negative time value */; return NULL;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
/* SYM_REF2(duration_c, neg, interval) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
void *visit(duration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
  TRACE("duration_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   424
  s4o.print("__time_to_timespec(");
547
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   425
  
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   426
  if (NULL == symbol->neg)    s4o.print("1");  /* positive time value */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   427
  else                        symbol->neg->accept(*this);  /* this will print '-1'   :-) */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   428
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   429
  s4o.print(", ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
  symbol->interval->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   434
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   435
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   436
/* SYM_TOKEN(fixed_point_c) */
312
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   437
void *visit(fixed_point_c *symbol) {return print_striped_token(symbol);}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
547
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   439
/* SYM_REF5(interval_c, days, hours, minutes, seconds, milliseconds) */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   440
void *visit(interval_c *symbol) {
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   441
  TRACE("interval_c");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   442
  /* s4o.print("0, 0, 0, 0, 0");  // milliseconds, seconds, minutes, hours, days */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   443
  if (NULL == symbol->milliseconds) s4o.print("0");  /* milliseconds */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   444
  else                              symbol->milliseconds->accept(*this);
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   445
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   446
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   447
  if (NULL == symbol->seconds)      s4o.print("0");  /* seconds */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   448
  else                              symbol->seconds->accept(*this);
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   449
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   450
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   451
  if (NULL == symbol->minutes)      s4o.print("0");  /* minutes */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   452
  else                              symbol->minutes->accept(*this);
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   453
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   454
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   455
  if (NULL == symbol->hours)        s4o.print("0");  /* hours */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   456
  else                              symbol->hours->accept(*this);
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   457
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   458
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   459
  if (NULL == symbol->days)         s4o.print("0");  /* days */
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   460
  else                              symbol->days->accept(*this);
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   461
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   462
  return NULL;
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   463
}
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   464
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
/************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   467
/* B 1.2.3.2 - Time of day and Date */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   468
/************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   469
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   470
/* SYM_REF2(time_of_day_c, daytime, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   471
void *visit(time_of_day_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   472
  TRACE("time_of_day_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   473
  s4o.print("__tod_to_timespec(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   474
  symbol->daytime->accept(*this);
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
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   477
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   478
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   479
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   480
/* SYM_REF4(daytime_c, day_hour, day_minute, day_second, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
void *visit(daytime_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
  TRACE("daytime_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
  symbol->day_second->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   484
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   485
  symbol->day_minute->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   486
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
  symbol->day_hour->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   488
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   489
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   490
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   491
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
/* SYM_REF2(date_c, date_literal, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
void *visit(date_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   494
  TRACE("date_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
  s4o.print("__date_to_timespec(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
  symbol->date_literal->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   497
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   500
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
/* SYM_REF4(date_literal_c, year, month, day, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   503
void *visit(date_literal_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
  TRACE("date_literal_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   505
  symbol->day->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   506
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   507
  symbol->month->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   508
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   509
  symbol->year->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   510
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   511
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   512
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   513
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   514
/* SYM_REF2(date_and_time_c, date_literal, daytime) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   515
void *visit(date_and_time_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   516
  TRACE("date_and_time_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   517
  s4o.print("__dt_to_timespec(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   518
  symbol->daytime->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   519
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   520
  symbol->date_literal->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   521
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   522
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   523
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   524
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   525
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   527
/* B.1.3 - Data types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   528
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   529
/***********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   530
/* B 1.3.1 - Elementary Data Types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   531
/***********************************/
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   532
    void *visit(time_type_name_c *symbol)        {s4o.print("TIME");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   533
    void *visit(bool_type_name_c *symbol)        {s4o.print("BOOL");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   534
    void *visit(sint_type_name_c *symbol)        {s4o.print("SINT");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   535
    void *visit(int_type_name_c *symbol)         {s4o.print("INT");         return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   536
    void *visit(dint_type_name_c *symbol)        {s4o.print("DINT");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   537
    void *visit(lint_type_name_c *symbol)        {s4o.print("LINT");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   538
    void *visit(usint_type_name_c *symbol)       {s4o.print("USINT");       return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   539
    void *visit(uint_type_name_c *symbol)        {s4o.print("UINT");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   540
    void *visit(udint_type_name_c *symbol)       {s4o.print("UDINT");       return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   541
    void *visit(ulint_type_name_c *symbol)       {s4o.print("ULINT");       return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   542
    void *visit(real_type_name_c *symbol)        {s4o.print("REAL");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   543
    void *visit(lreal_type_name_c *symbol)       {s4o.print("LREAL");       return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   544
    void *visit(date_type_name_c *symbol)        {s4o.print("DATE");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   545
    void *visit(tod_type_name_c *symbol)         {s4o.print("TOD");         return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   546
    void *visit(dt_type_name_c *symbol)          {s4o.print("DT");          return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   547
    void *visit(byte_type_name_c *symbol)        {s4o.print("BYTE");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   548
    void *visit(word_type_name_c *symbol)        {s4o.print("WORD");        return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   549
    void *visit(lword_type_name_c *symbol)       {s4o.print("LWORD");       return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   550
    void *visit(dword_type_name_c *symbol)       {s4o.print("DWORD");       return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   551
    void *visit(string_type_name_c *symbol)      {s4o.print("STRING");      return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   552
    void *visit(wstring_type_name_c *symbol)     {s4o.print("WSTRING");     return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   553
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   554
    void *visit(safetime_type_name_c *symbol)    {s4o.print("TIME");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   555
    void *visit(safebool_type_name_c *symbol)    {s4o.print("BOOL");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   556
    void *visit(safesint_type_name_c *symbol)    {s4o.print("SINT");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   557
    void *visit(safeint_type_name_c *symbol)     {s4o.print("INT");     return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   558
    void *visit(safedint_type_name_c *symbol)    {s4o.print("DINT");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   559
    void *visit(safelint_type_name_c *symbol)    {s4o.print("LINT");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   560
    void *visit(safeusint_type_name_c *symbol)   {s4o.print("USINT");   return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   561
    void *visit(safeuint_type_name_c *symbol)    {s4o.print("UINT");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   562
    void *visit(safeudint_type_name_c *symbol)   {s4o.print("UDINT");   return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   563
    void *visit(safeulint_type_name_c *symbol)   {s4o.print("ULINT");   return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   564
    void *visit(safereal_type_name_c *symbol)    {s4o.print("REAL");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   565
    void *visit(safelreal_type_name_c *symbol)   {s4o.print("LREAL");   return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   566
    void *visit(safedate_type_name_c *symbol)    {s4o.print("DATE");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   567
    void *visit(safetod_type_name_c *symbol)     {s4o.print("TOD");     return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   568
    void *visit(safedt_type_name_c *symbol)      {s4o.print("DT");      return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   569
    void *visit(safebyte_type_name_c *symbol)    {s4o.print("BYTE");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   570
    void *visit(safeword_type_name_c *symbol)    {s4o.print("WORD");    return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   571
    void *visit(safelword_type_name_c *symbol)   {s4o.print("LWORD");   return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   572
    void *visit(safedword_type_name_c *symbol)   {s4o.print("DWORD");   return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   573
    void *visit(safestring_type_name_c *symbol)  {s4o.print("STRING");  return NULL;}
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   574
    void *visit(safewstring_type_name_c *symbol) {s4o.print("WSTRING"); return NULL;}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   575
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   576
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   577
/* B.1.3.2 - Generic data types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   578
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   579
  /* originally empty... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   580
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   581
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   582
/* B 1.3.3 - Derived data types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   583
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   584
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   585
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   586
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   587
/* B 1.4 - Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   588
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   589
void *visit(symbolic_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   590
  TRACE("symbolic_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   591
  this->print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   592
  symbol->var_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   593
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   594
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   595
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   596
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   597
/* B.1.4.1   Directly Represented Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   598
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   599
void *visit(direct_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   600
  TRACE("direct_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   601
  /* Do not use print_token() as it will change everything into uppercase */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   602
  return s4o.printlocation(symbol->value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   603
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   604
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   605
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   606
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   607
/*************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   608
/* B.1.4.2   Multi-element Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   609
/*************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   610
#if 0
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   611
/*  subscripted_variable '[' subscript_list ']' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   612
SYM_REF2(array_variable_c, subscripted_variable, subscript_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   613
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   614
#endif
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   615
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   616
/*  record_variable '.' field_selector */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   617
/*  WARNING: input and/or output variables of function blocks
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   618
 *           may be accessed as fields of a structured variable!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   619
 *           Code handling a structured_variable_c must take
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   620
 *           this into account!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   621
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   622
// SYM_REF2(structured_variable_c, record_variable, field_selector)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   623
void *visit(structured_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   624
  TRACE("structured_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   625
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   626
  symbol->record_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   627
  s4o.print(".");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   628
  symbol->field_selector->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   629
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   630
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   631
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   632
/******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   633
/* B 1.4.3 - Declaration & Initialisation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   634
/******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   635
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   636
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   637
/**************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   638
/* B.1.5 - Program organization units */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   639
/**************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   640
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   641
/* B 1.5.1 - Functions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   642
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   643
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   644
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   645
/*****************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   646
/* B 1.5.2 - Function Blocks */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   647
/*****************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   648
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   649
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   650
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   651
/* B 1.5.3 - Programs */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   652
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   653
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   654
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   655
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   656
/* B.1.6  Sequential function chart elements */
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
/* B 1.7 Configuration elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   661
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   662
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   663
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   664
/****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   665
/* B.2 - Language IL (Instruction List) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   666
/****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   667
/***********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   668
/* B 2.1 Instructions and Operands */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   669
/***********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   670
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   671
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   672
/*******************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   673
/* B 2.2 Operators */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   674
/*******************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   675
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   676
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   677
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   678
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   679
/* B.3 - Language ST (Structured Text) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   680
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   681
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   682
/* B 3.1 - Expressions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   683
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   684
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   685
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   686
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   687
/* B 3.2 Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   688
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   689
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   690
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   691
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   692
/* B 3.2.1 Assignment Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   693
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   694
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   695
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   696
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   697
/* B 3.2.2 Subprogram Control Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   698
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   699
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   700
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   701
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   702
/* B 3.2.3 Selection Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   703
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   704
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   705
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   706
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   707
/* B 3.2.4 Iteration Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   708
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   709
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   710
177
697562a5da7c Adding support for SAFEBOOL. Some code generation yet to do...
mario
parents: 160
diff changeset
   711
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   712
}; /* class generate_c_basic_c */
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
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   716
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   717
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   718
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   719
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   720
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   721
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   722
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   723
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   724
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   725
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   726