stage4/generate_c/generate_c_base.cc
author mjsousa
Sun, 09 Nov 2014 22:02:34 +0000
changeset 944 d6d9211e9aab
parent 936 0f7bcc160568
child 947 aca1ab9fcb6d
permissions -rw-r--r--
fix bug introduced a few commits ago: do not print the first char ('%') of a direct_variable_c (e.g. skip % in %IW4.2)
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
877
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
    93
    void print_line_directive(symbol_c *symbol) {
878
89eb85bab58f Make generation of #line directives optional.
mjsousa
parents: 877
diff changeset
    94
      if (!generate_line_directives__) return; /* global variable generate_line_directives__ is defined in generate_c.cc */
877
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
    95
      s4o.print("#line ");
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
    96
      s4o.print(symbol->first_line);
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
    97
      s4o.print(" \"");
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
    98
      s4o.print(symbol->first_file);
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
    99
      s4o.print("\"\n");    
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
   100
    }
c25346eac788 Insert #line directives in generated C code.
mjsousa
parents: 860
diff changeset
   101
    
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
    void *print_token(token_c *token, int offset = 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
      return s4o.printupper((token->value)+offset);
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_literal(symbol_c *type, symbol_c *value) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
      s4o.print("__");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
      type->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   109
      s4o.print("_LITERAL(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   110
      value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   111
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   112
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   114
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
    void *print_striped_token(token_c *token, int offset = 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
      std::string str = "";
312
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   117
      bool leading_zero = true;
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   118
      for (unsigned int i = offset; i < strlen(token->value); i++) {
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   119
        if (leading_zero
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   120
            && (   token->value[i] != '0'
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   121
                || i == strlen(token->value) - 1
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   122
                || token->value[i + 1] == '.'
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   123
                )
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   124
            )
312
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   125
          leading_zero = false;
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   126
            if (!leading_zero && token->value[i] != '_')
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
          str += token->value[i];
312
29add821207d Fix bug when generating integer with leading zero (octal value for C compiler)
laurent
parents: 308
diff changeset
   128
      }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
      return s4o.printupper(str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
    void *print_striped_binary_token(token_c *token, unsigned int offset = 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   133
      /* convert the binary value to hexadecimal format... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   134
      unsigned char value, bit_mult;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   135
      unsigned int i;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   136
      int total_bits;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
      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
   138
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
      s4o.print("0x");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
      total_bits = 0;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
      for (i = offset; i < strlen(token->value); i++)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   143
        if (token->value[i] != '_')
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   144
          total_bits++;
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
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
      bit_mult = (unsigned char)1 << (((total_bits+3)%4)+1);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
      for (i = offset; i < strlen(token->value); i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
        if (token->value[i] != '_') {
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   150
          bit_mult /= 2;
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   151
          value += bit_mult * ((token->value[i] == '0')? 0:1);
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   152
          if (bit_mult == 1) {
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   153
            str[0] = (value <= 9)? (char)'0' + value : (char)'A' + value - 10;
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   154
            s4o.print(str);
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
            bit_mult = 0x10;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   156
            value = 0;
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   157
          }
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   158
        }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   159
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   160
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   161
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   163
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   164
    void *print_list(list_c *list,
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   165
                     std::string pre_elem_str = "",
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   166
                     std::string inter_elem_str = "",
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   167
                     std::string post_elem_str = "",
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   168
                     visitor_c *visitor = NULL) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   169
      if (visitor == NULL) visitor = this;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   170
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   171
      if (list->n > 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
//std::cout << "generate_c_base_c::print_list(n = " << list->n << ")   000\n";
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   173
        s4o.print(pre_elem_str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
        list->elements[0]->accept(*visitor);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   175
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   176
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   177
      for(int i = 1; i < list->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   178
//std::cout << "generate_c_base_c::print_list   " << i << "\n";
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   179
        s4o.print(inter_elem_str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
        list->elements[i]->accept(*visitor);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
      if (list->n > 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
        s4o.print(post_elem_str);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   187
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   188
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
    void *print_binary_expression(symbol_c *l_exp,
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   191
                                  symbol_c *r_exp,
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   192
                                  const char *operation) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
      s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
      l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
      s4o.print(operation);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
      r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   197
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   199
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
    void *print_unary_expression(symbol_c *exp,
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   202
                                 const char *operation) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   203
      s4o.print(operation);
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
      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
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   210
    void *print_binary_function(const char *function,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   211
          symbol_c *l_exp,
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   212
          symbol_c *r_exp) {
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   213
      s4o.print(function);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
      s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
      l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
      s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
      r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   218
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
      return NULL;
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   220
    }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
    void *print_compare_function(const char *function,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
          symbol_c *compare_type,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
          symbol_c *l_exp,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
          symbol_c *r_exp) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   226
      s4o.print(function);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   227
      compare_type->accept(*this);
149
05ca171a3d57 Adding support for EN/ENO in standard functions
lbessard
parents: 146
diff changeset
   228
      s4o.print("(__BOOL_LITERAL(TRUE), NULL, 2, ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   229
      l_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   230
      s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   231
      r_exp->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   232
      s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   233
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   234
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   235
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   236
    void *print_check_function(symbol_c *type,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   237
          symbol_c *value,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   238
          symbol_c *fb_name = NULL,
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   239
          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
   240
      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
   241
      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
   242
      if (is_subrange) {
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   243
        s4o.print("__CHECK_");
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   244
        type->accept(*this);
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   245
        s4o.print("(");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   246
      }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   247
      if (fb_name != NULL) {
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   248
        s4o.print(GET_VAR);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   249
        s4o.print("(");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   250
        print_variable_prefix();
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   251
        fb_name->accept(*this);
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   252
        s4o.print(".");
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   253
        value->accept(*this);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   254
        s4o.print(")");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   255
      }
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   256
      else {
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   257
        if (temp)
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   258
        s4o.print(TEMP_VAR);
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   259
        value->accept(*this);
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   260
      }
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   261
      if (is_subrange)
240
f78fa87bb4cb Bugs fixed:
laurent
parents: 217
diff changeset
   262
        s4o.print(")");
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   263
      return NULL;
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   264
    }
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   265
267
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   266
/********************/
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   267
/* 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
   268
/********************/
0a1204bcc9af starting to add proper header file with declaration of standard functions
Mario de Sousa <msousa@fe.up.pt>
parents: 258
diff changeset
   269
    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
   270
    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
   271
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   272
    /* 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
   273
    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
   274
        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
   275
        s4o.print(s4o.indent_spaces);
886
111414d79ecd Finish: Change order of SET_xxx() macros. (this will allow me to simplify the print_setter() methods later on)
mjsousa
parents: 878
diff changeset
   276
        s4o.print("#define SetFbVar(var,val,...) __SET_VAR(data__->,var,__VA_ARGS__,val)\n");
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
   277
        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
   278
        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
   279
        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
   280
        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
   281
        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
   282
        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
   283
        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
   284
    }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   288
/* B 0 - Programming Model */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
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
/*************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
/* B.1 - Common elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   296
/*************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   297
/*******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
/* B 1.1 - Letters, digits and identifiers */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   299
/*******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
    void *visit(identifier_c *symbol) {return print_token(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   301
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
/* B 1.2 - Constants */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
  /* originally empty... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
919
8da635655f37 Add support for the 'NULL' keyword, defined in version 3 of IEC 61131-3.
mjsousa
parents: 886
diff changeset
   307
/*********************************/
8da635655f37 Add support for the 'NULL' keyword, defined in version 3 of IEC 61131-3.
mjsousa
parents: 886
diff changeset
   308
/* B 1.2.XX - Reference Literals */
8da635655f37 Add support for the 'NULL' keyword, defined in version 3 of IEC 61131-3.
mjsousa
parents: 886
diff changeset
   309
/*********************************/
8da635655f37 Add support for the 'NULL' keyword, defined in version 3 of IEC 61131-3.
mjsousa
parents: 886
diff changeset
   310
/* defined in IEC 61131-3 v3 - Basically the 'NULL' keyword! */
8da635655f37 Add support for the 'NULL' keyword, defined in version 3 of IEC 61131-3.
mjsousa
parents: 886
diff changeset
   311
    void *visit(ref_value_null_literal_c *symbol) {s4o.print("NULL"); return NULL;}
8da635655f37 Add support for the 'NULL' keyword, defined in version 3 of IEC 61131-3.
mjsousa
parents: 886
diff changeset
   312
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313
/******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   314
/* B 1.2.1 - Numeric Literals */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   315
/******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   316
    void *visit(real_c *symbol) {return print_striped_token(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   317
    void *visit(integer_c *symbol) {return print_striped_token(symbol);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   318
    void *visit(binary_integer_c *symbol) {return print_striped_binary_token(symbol, 2);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
    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
   320
    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
   321
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   322
    void *visit(neg_real_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   323
      s4o.print("-");
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   324
      symbol->exp->accept(*this);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   325
      return NULL;
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   326
    }
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   327
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   328
    void *visit(neg_integer_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   329
      s4o.print("-");
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   330
      symbol->exp->accept(*this);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   331
      return NULL;
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   332
    }
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   333
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   334
    void *visit(integer_literal_c *symbol) {return print_literal(symbol->type, symbol->value);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   335
    void *visit(real_literal_c *symbol) {return print_literal(symbol->type, symbol->value);}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   336
    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
   337
    void *visit(boolean_literal_c *symbol) {
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   338
      if (NULL != symbol->type)
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   339
        return print_literal(symbol->type, symbol->value);
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   340
      else {
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   341
        bool_type_name_c bool_type;
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   342
        return print_literal(&bool_type, symbol->value);
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   343
      }
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   344
    }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   345
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   346
    /* helper class for boolean_literal_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   347
    void *visit(boolean_true_c *symbol) {s4o.print("TRUE"); return NULL;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   348
    void *visit(boolean_false_c *symbol) {s4o.print("FALSE"); return NULL;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   349
98
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   350
    void *visit(neg_expression_c *symbol) {
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   351
      s4o.print("-");
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   352
      symbol->exp->accept(*this);
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   353
      return NULL;
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   354
    }
d0cdf1d00b74 Adding support for derived data types.
lbessard
parents: 70
diff changeset
   355
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   356
/*******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   357
/* B.1.2.2   Character Strings */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   358
/*******************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   359
    void *visit(double_byte_character_string_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   360
      // TO DO ...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   361
      ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   362
      return print_token(symbol);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   363
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   364
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   365
    void *visit(single_byte_character_string_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   366
      std::string str = "";
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   367
      unsigned int count = 0; 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   368
      str += '"';
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   369
      /* we ignore the first and last bytes, they will be the character ' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   370
      for (unsigned int i = 1; i < strlen(symbol->value) - 1; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   371
        char c = symbol->value[i];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   372
        if ((c == '\\') || (c == '"'))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   373
          {str += '\\'; str += c; count ++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   374
        if (c != '$')
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   375
          {str += c; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   376
        /* this should be safe, since the code has passed the syntax parser!! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   377
        c = symbol->value[++i];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   378
        switch (c) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   379
          case '$':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   380
          case '\'':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   381
            {str += c; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   382
          case 'L':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   383
          case 'l':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   384
            {str += "\x0A"; /* LF */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   385
          case 'N':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   386
          case 'n':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   387
            {str += "\\x0A"; /* NL */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   388
          case 'P':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   389
          case 'p':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   390
            {str += "\\f"; /* FF */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   391
          case 'R':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   392
          case 'r':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   393
            {str += "\\r"; /* CR */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   394
          case 'T':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   395
          case 't':
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   396
            {str += "\\t"; /* tab */; count++; continue;}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   397
          default: {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
            if (isxdigit(c)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   399
              /* this should be safe, since the code has passed the syntax parser!! */
927
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   400
              char c2 = symbol->value[++i];
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   401
              if (isxdigit(c2)) {
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   402
                str += '\\'; str += 'x'; str += c; str += c2;
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   403
                count++; continue;
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   404
              }
39b596670e33 fix indentations.
mjsousa
parents: 923
diff changeset
   405
            }
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
          }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
          /* otherwise we have an invalid string!! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
          /* This should not have got through the syntax parser! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
          ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   410
        } /* switch() */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   411
      } /* for() */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   412
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
      str += '"';
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   414
      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
   415
      s4o.print(count); 
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
      s4o.print(",");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
      s4o.print(str);
217
f5dfadf5de54 Adding support for declare, init, get and set macros
laurent
parents: 202
diff changeset
   418
      s4o.print(")");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   424
/* B 1.2.3 - Time Literals */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   425
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   426
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   427
/************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   428
/* B 1.2.3.1 - Duration */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   429
/************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
/* 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
   431
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
/* SYM_REF0(neg_time_c) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
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
   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_REF2(duration_c, neg, interval) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   437
void *visit(duration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
  TRACE("duration_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   439
  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
   440
  
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   441
  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
   442
  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
   443
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   444
  s4o.print(", ");
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   445
  symbol->interval->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   446
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   447
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   448
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   449
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   450
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
/* 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
   452
void *visit(fixed_point_c *symbol) {return print_striped_token(symbol);}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
547
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   454
/* 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
   455
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
   456
  TRACE("interval_c");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   457
  /* 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
   458
  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
   459
  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
   460
  s4o.print(", ");
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
  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
   463
  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
   464
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   465
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   466
  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
   467
  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
   468
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   469
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   470
  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
   471
  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
   472
  s4o.print(", ");
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   473
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   474
  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
   475
  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
   476
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   477
  return NULL;
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   478
}
dab341e80664 Fix parsing os TIME literals & rename the extract_integer() function.
mjsousa <msousa@fe.up.pt>
parents: 312
diff changeset
   479
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   480
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
/************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
/* B 1.2.3.2 - Time of day and Date */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
/************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   484
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   485
/* SYM_REF2(time_of_day_c, daytime, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   486
void *visit(time_of_day_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
  TRACE("time_of_day_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   488
  s4o.print("__tod_to_timespec(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   489
  symbol->daytime->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   490
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   491
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   494
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
/* SYM_REF4(daytime_c, day_hour, day_minute, day_second, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
void *visit(daytime_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   497
  TRACE("daytime_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
  symbol->day_second->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   500
  symbol->day_minute->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
  symbol->day_hour->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   503
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   505
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   506
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   507
/* SYM_REF2(date_c, date_literal, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   508
void *visit(date_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   509
  TRACE("date_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   510
  s4o.print("__date_to_timespec(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   511
  symbol->date_literal->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   512
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   513
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   514
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   515
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   516
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   517
/* SYM_REF4(date_literal_c, year, month, day, unused) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   518
void *visit(date_literal_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   519
  TRACE("date_literal_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   520
  symbol->day->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
  symbol->month->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   523
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   524
  symbol->year->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   525
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   527
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   528
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   529
/* SYM_REF2(date_and_time_c, date_literal, daytime) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   530
void *visit(date_and_time_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   531
  TRACE("date_and_time_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   532
  s4o.print("__dt_to_timespec(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   533
  symbol->daytime->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   534
  s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   535
  symbol->date_literal->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   536
  s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   537
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   538
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   539
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   540
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   541
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   542
/* B.1.3 - Data types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   543
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   544
/***********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   545
/* B 1.3.1 - Elementary Data Types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   546
/***********************************/
257
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   547
    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
   548
    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
   549
    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
   550
    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
   551
    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
   552
    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
   553
    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
   554
    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
   555
    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
   556
    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
   557
    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
   558
    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
   559
    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
   560
    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
   561
    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
   562
    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
   563
    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
   564
    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
   565
    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
   566
    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
   567
    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
   568
90782e241346 Huge change.
Mario de Sousa <msousa@fe.up.pt>
parents: 202
diff changeset
   569
    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
   570
    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
   571
    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
   572
    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
   573
    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
   574
    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
   575
    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
   576
    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
   577
    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
   578
    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
   579
    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
   580
    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
   581
    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
   582
    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
   583
    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
   584
    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
   585
    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
   586
    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
   587
    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
   588
    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
   589
    void *visit(safewstring_type_name_c *symbol) {s4o.print("WSTRING"); return NULL;}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   590
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   591
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   592
/* B.1.3.2 - Generic data types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   593
/********************************/
923
0ad7843d3790 Add support for non standard REF_TO ANY (equivalent to void *)
mjsousa
parents: 919
diff changeset
   594
    /* Currently only used in REF_TO ANY, which is mapped onto (void *) */
0ad7843d3790 Add support for non standard REF_TO ANY (equivalent to void *)
mjsousa
parents: 919
diff changeset
   595
    void *visit(generic_type_any_c *symbol)      {s4o.print("void");    return NULL;}
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   596
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   597
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   598
/* B 1.3.3 - Derived data types */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   599
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   600
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   601
860
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   602
  
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   603
/* enumerated_type_name '#' identifier */
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   604
void *visit(enumerated_value_c *symbol) {
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   605
  if (NULL == symbol->datatype) {
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   606
    debug_c::print(symbol);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   607
    ERROR;
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   608
  }
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   609
  
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   610
  symbol_c *type_name = get_datatype_info_c::get_id(symbol->datatype);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   611
  if (NULL == type_name) {
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   612
    ERROR_MSG("C code generator does not currently support anonymous enumerated data types.");
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   613
  }
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   614
  
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   615
  type_name->accept(*this);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   616
  s4o.print("__");
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   617
  symbol->value->accept(*this);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   618
  return NULL;
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   619
}
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   620
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   621
928
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   622
/*  identifier ':' array_spec_init */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   623
void *visit(array_type_declaration_c *symbol) {ERROR;/* Should never get called! */ return NULL;}
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   624
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   625
/* array_specification [ASSIGN array_initialization] */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   626
/* array_initialization may be NULL ! */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   627
void *visit(array_spec_init_c *symbol) {
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   628
  int implicit_id_count = symbol->anotations_map.count("generate_c_annotaton__implicit_type_id");
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   629
  if (implicit_id_count != 1) ERROR;
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   630
  /* this is part of an implicitly declared datatype (i.e. inside a variable decaration), for which an equivalent C datatype
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   631
   * has already been defined. So, we simly print out the id of that C datatpe...
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   632
   */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   633
  return symbol->anotations_map["generate_c_annotaton__implicit_type_id"]->accept(*this);
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   634
}
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   635
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   636
/* ARRAY '[' array_subrange_list ']' OF non_generic_type_name */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   637
void *visit(array_specification_c *symbol) {
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   638
  int implicit_id_count = symbol->anotations_map.count("generate_c_annotaton__implicit_type_id");
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   639
  if (implicit_id_count != 1) ERROR;
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   640
  /* this is part of an implicitly declared datatype (i.e. inside a variable decaration), for which an equivalent C datatype
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   641
   * has already been defined. So, we simly print out the id of that C datatpe...
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   642
   */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   643
  return symbol->anotations_map["generate_c_annotaton__implicit_type_id"]->accept(*this);
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   644
}
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   645
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   646
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   647
/* ref_spec:  REF_TO (non_generic_type_name | function_block_type_name) */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   648
void *visit(ref_spec_c *symbol) {
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   649
  int implicit_id_count = symbol->anotations_map.count("generate_c_annotaton__implicit_type_id");
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   650
  if (implicit_id_count != 1) ERROR;
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   651
  /* this is part of an implicitly declared datatype (i.e. inside a variable decaration), for which an equivalent C datatype
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   652
   * has already been defined. So, we simly print out the id of that C datatpe...
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   653
   */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   654
  return symbol->anotations_map["generate_c_annotaton__implicit_type_id"]->accept(*this);
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   655
}
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   656
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   657
/* For the moment, we do not support initialising reference data types */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   658
/* ref_spec_init: ref_spec [ ASSIGN ref_initialization ] */ 
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   659
/* NOTE: ref_initialization may be NULL!! */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   660
// SYM_REF2(ref_spec_init_c, ref_spec, ref_initialization)
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   661
void *visit(ref_spec_init_c *symbol) {
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   662
  int implicit_id_count = symbol->anotations_map.count("generate_c_annotaton__implicit_type_id");
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   663
  if (implicit_id_count != 1) ERROR;
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   664
  /* this is part of an implicitly declared datatype (i.e. inside a variable decaration), for which an equivalent C datatype
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   665
   * has already been defined. So, we simly print out the id of that C datatpe...
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   666
   */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   667
  return symbol->anotations_map["generate_c_annotaton__implicit_type_id"]->accept(*this);
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   668
}
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   669
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   670
/* ref_type_decl: identifier ':' ref_spec_init */
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   671
void *visit(ref_type_decl_c *symbol) {ERROR;/* Should never get called! */ return NULL;}
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   672
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   673
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   674
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   675
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   676
860
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   677
/* NOTE:     visit(subrange_spec_init_c *)
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   678
 *      and  visit(subrange_specification_c *)
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   679
 *      together simply print out the integer datatype
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   680
 *      on which the subrange is based.
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   681
 *
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   682
 *      Future code clean-ups should delete these two
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   683
 *      visit mehotds, and make sure whoever calls them 
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   684
 *      uses symbol->datatype instead!
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   685
 */ 
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   686
/* subrange_specification ASSIGN signed_integer */
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   687
void *visit(subrange_spec_init_c *symbol) {
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   688
  TRACE("subrange_spec_init_c");
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   689
  symbol->subrange_specification->accept(*this);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   690
  return NULL;
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   691
}
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   692
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   693
/*  integer_type_name '(' subrange')' */
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   694
void *visit(subrange_specification_c *symbol) {
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   695
  TRACE("subrange_specification_c");
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   696
  symbol->integer_type_name->accept(*this);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   697
  return NULL;
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   698
}
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   699
  
928
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   700
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   701
/* NOTE: Why is this here? This visit() method should not be here!!
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   702
 * TODO: Figure out who is dependent on this method, and move it to its correct location!
fa7a6800503d Fix calling of functions whose parameters are of an implicitly declared datatype (currently only makes sense for REF_TO datatypes, but may make sense to other datatypes too if the datatype model is changed in the future).
mjsousa
parents: 927
diff changeset
   703
 */
860
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   704
/* helper symbol for array_specification */
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   705
/* array_subrange_list ',' subrange */
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   706
void *visit(array_subrange_list_c *symbol) {
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   707
  TRACE("array_subrange_list_c");
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   708
  print_list(symbol);
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   709
  return NULL;
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   710
}  
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   711
  
7669a8d43c11 Code cleanup (part 2): generate_typedecl_c now only prints to POUS.h !
mjsousa
parents: 854
diff changeset
   712
  
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   713
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   714
/* B 1.4 - Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   715
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   716
void *visit(symbolic_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   717
  TRACE("symbolic_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   718
  this->print_variable_prefix();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   719
  symbol->var_name->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   720
  return NULL;
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
/* B.1.4.1   Directly Represented Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   725
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   726
void *visit(direct_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   727
  TRACE("direct_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   728
  /* Do not use print_token() as it will change everything into uppercase */
944
d6d9211e9aab fix bug introduced a few commits ago: do not print the first char ('%') of a direct_variable_c (e.g. skip % in %IW4.2)
mjsousa
parents: 936
diff changeset
   729
  return s4o.printlocation(symbol->value+1); // '+1' so we do not print the '%' in '%IW3.2'
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   730
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   731
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   732
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   733
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   734
/*************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   735
/* B.1.4.2   Multi-element Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   736
/*************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   737
#if 0
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   738
/*  subscripted_variable '[' subscript_list ']' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   739
SYM_REF2(array_variable_c, subscripted_variable, subscript_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   740
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   741
#endif
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   742
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   743
/*  record_variable '.' field_selector */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   744
/*  WARNING: input and/or output variables of function blocks
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   745
 *           may be accessed as fields of a structured variable!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   746
 *           Code handling a structured_variable_c must take
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   747
 *           this into account!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   748
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   749
// SYM_REF2(structured_variable_c, record_variable, field_selector)
936
0f7bcc160568 Fix bug: Add support for de-referencing pointers to struct (struct_ptr^.elem1) when used inside FB.
mjsousa
parents: 928
diff changeset
   750
// TODO:  It seems to me this code no longer gets to execute, since the function is overloaded in generate_c_st_c and generate_c_il_c
0f7bcc160568 Fix bug: Add support for de-referencing pointers to struct (struct_ptr^.elem1) when used inside FB.
mjsousa
parents: 928
diff changeset
   751
//        I will have to check this later, and delete this code if the above is really true!
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   752
void *visit(structured_variable_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   753
  TRACE("structured_variable_c");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   754
  symbol->record_variable->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   755
  s4o.print(".");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   756
  symbol->field_selector->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   757
  return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   758
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   759
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   760
/******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   761
/* B 1.4.3 - Declaration & Initialisation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   762
/******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   763
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   764
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   765
/**************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   766
/* B.1.5 - Program organization units */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   767
/**************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   768
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   769
/* B 1.5.1 - Functions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   770
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   771
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   772
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   773
/*****************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   774
/* B 1.5.2 - Function Blocks */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   775
/*****************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   776
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   777
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   778
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   779
/* B 1.5.3 - Programs */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   780
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   781
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   782
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   783
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   784
/* B.1.6  Sequential function chart elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   785
/*********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   786
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   787
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   788
/* B 1.7 Configuration elements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   789
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   790
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   791
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   792
/****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   793
/* B.2 - Language IL (Instruction List) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   794
/****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   795
/***********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   796
/* B 2.1 Instructions and Operands */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   797
/***********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   798
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   799
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   800
/*******************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   801
/* B 2.2 Operators */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   802
/*******************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   803
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   804
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   805
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   806
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   807
/* B.3 - Language ST (Structured Text) */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   808
/***************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   809
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   810
/* B 3.1 - Expressions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   811
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   812
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   813
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   814
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   815
/* B 3.2 Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   816
/********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   817
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   818
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   819
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   820
/* B 3.2.1 Assignment Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   821
/*********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   822
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   823
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   824
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   825
/* B 3.2.2 Subprogram Control Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   826
/*****************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   827
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   828
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   829
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   830
/* B 3.2.3 Selection Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   831
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   832
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   833
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   834
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   835
/* B 3.2.4 Iteration Statements */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   836
/********************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   837
  /* leave for derived classes... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   838
177
697562a5da7c Adding support for SAFEBOOL. Some code generation yet to do...
mario
parents: 160
diff changeset
   839
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   840
}; /* class generate_c_basic_c */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   841
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   842
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   843
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   844
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   845
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   846
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   847
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   848
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   849
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   850
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   851
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   852
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   853
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   854