stage4/generate_c/search_var_instance_decl.cc
author lbessard
Wed, 24 Oct 2007 17:39:51 +0200
changeset 70 e1f0ebd2d9ec
child 117 550c3bd2df16
permissions -rwxr-xr-x
Change generate_cc to generate_c
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     1
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     2
 * (c) 2003 Mario de Sousa
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     3
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     4
 * Offered to the public under the terms of the GNU General Public License
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     5
 * as published by the Free Software Foundation; either version 2 of the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     6
 * License, or (at your option) any later version.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     7
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     8
 * This program is distributed in the hope that it will be useful, but
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     9
 * WITHOUT ANY WARRANTY; without even the implied warranty of
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    10
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    11
 * Public License for more details.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    12
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    13
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    14
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    15
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    16
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    17
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    18
 * An IEC 61131-3 IL and ST compiler.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    19
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 * Based on the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * FINAL DRAFT - IEC 61131-3, 2nd Ed. (2001-12-10)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    23
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    24
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    25
/* Determine the data type of a specific variable instance, including
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    26
 * function block instances.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    27
 * A reference to the relevant variable declaration is returned.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
 * The variable instance may NOT be a member of a structure of a memeber
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
 * of a structure of an element of an array of ...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    30
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    31
 * example:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    32
 *    window.points[1].coordinate.x
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    33
 *    window.points[1].colour
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    34
 *    etc... ARE NOT ALLOWED!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    35
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    36
 * This class must only be passed the name of the variable that will appear
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    37
 * in the variable declaration. In the above examples, this would be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    38
 *   'window' !!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    39
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    40
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    41
 * If you need to pass a complete name of a variable instance (such as
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    42
 * 'window.points[1].coordinate.x') use the search_varfb_instance_type_c instead!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    43
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    44
/* Note that current_type_decl that this class returns may reference the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    45
 * name of a type, or the type declaration itself!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    46
 * For an example of the first, consider a variable declared as ...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    47
 * x : AAA;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    48
 * where the AAA type is previously declared as whatever.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    49
 * For an example of the second, consider a variable declared as ...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    50
 * x : array of int [10];  ---->  is allowed
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    51
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    52
 * If it is the first, we will return a reference to the name, if the second
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    53
 * we return a reference to the declaration!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    54
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    55
class search_var_instance_decl_c: public search_visitor_c {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    56
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    57
  private:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    58
    symbol_c *search_scope;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    59
    symbol_c *search_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    60
    symbol_c *current_type_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
    /* variable used to store the type of variable currently being processed... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
    /* Will contain a single value of generate_c_vardecl_c::XXXX_vt */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
    unsigned int current_vartype;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
    search_var_instance_decl_c(symbol_c *search_scope) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
      this->current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
      this->search_scope = search_scope;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
      this->search_name = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
      this->current_type_decl = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
    symbol_c *get_decl(symbol_c *variable_instance_name) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
      this->search_name = variable_instance_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
      return (symbol_c *)search_scope->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    78
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    79
    unsigned int get_vartype() {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    80
      return current_vartype;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    81
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    82
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
  public:
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
  
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
    /* the types of variables that need to be processed... */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    86
    static const unsigned int none_vt   = 0x0000;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
    static const unsigned int input_vt    = 0x0001;  // VAR_INPUT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
    static const unsigned int output_vt   = 0x0002;  // VAR_OUTPUT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    89
    static const unsigned int inoutput_vt = 0x0004;  // VAR_IN_OUT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    90
    static const unsigned int private_vt  = 0x0008;  // VAR
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
    static const unsigned int temp_vt   = 0x0010;  // VAR_TEMP
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
    static const unsigned int external_vt = 0x0020;  // VAR_EXTERNAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    93
    static const unsigned int global_vt = 0x0040;  // VAR_GLOBAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    94
    static const unsigned int located_vt  = 0x0080;  // VAR <var_name> AT <location>
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    95
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    96
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    97
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
/* B 0 - Programming Model */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    99
/***************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   100
    void *visit(library_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   101
      /* we do not want to search multiple declaration scopes,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
       * so we do not visit all the functions, fucntion blocks, etc...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   109
/******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   110
/* B 1.4.3 - Declaration & Initialisation */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   111
/******************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   112
/* edge -> The F_EDGE or R_EDGE directive */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
// SYM_REF2(edge_declaration_c, edge, var1_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   114
// TODO
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
    void *visit(input_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
      current_vartype = input_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
      void *res = symbol->input_declaration_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   120
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   121
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   122
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   123
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   124
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   125
/* VAR_OUTPUT [RETAIN | NON_RETAIN] var_init_decl_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   126
/* option -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
    void *visit(output_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   128
      current_vartype = output_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
      void *res = symbol->var_init_decl_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   133
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   134
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   135
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   136
/*  VAR_IN_OUT var_declaration_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
    void *visit(input_output_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   138
      current_vartype = inoutput_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
      void *res = symbol->var_declaration_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   143
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   146
/* VAR [CONSTANT] var_init_decl_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   147
/* option -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
/* helper symbol for input_declarations */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
    void *visit(var_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   150
      current_vartype = private_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   151
      void *res = symbol->var_init_decl_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   152
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   153
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   154
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   156
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   157
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   158
/*  VAR RETAIN var_init_decl_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   159
    void *visit(retentive_var_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   160
      current_vartype = private_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   161
      void *res = symbol->var_init_decl_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   163
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   164
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   165
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   166
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   167
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   168
/*  VAR [CONSTANT|RETAIN|NON_RETAIN] located_var_decl_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   169
/* option -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   170
//SYM_REF2(located_var_declarations_c, option, located_var_decl_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   171
    void *visit(located_var_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
      current_vartype = located_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   173
      void *res = symbol->located_var_decl_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   175
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   176
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   177
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   178
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   179
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
/*| VAR_EXTERNAL [CONSTANT] external_declaration_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
/* option -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
//SYM_REF2(external_var_declarations_c, option, external_declaration_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
    void *visit(external_var_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
      current_vartype = external_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
      void *res = symbol->external_declaration_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   187
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   188
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   189
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
/*| VAR_GLOBAL [CONSTANT|RETAIN] global_var_decl_list END_VAR */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
/* option -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
//SYM_REF2(global_var_declarations_c, option, global_var_decl_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
    void *visit(global_var_declarations_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
      current_vartype = global_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   197
      void *res = symbol->global_var_decl_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
      if (res == NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   199
        current_vartype = none_vt;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
      return res;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   202
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   203
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   204
/* var1_list is one of the following...
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   205
 *    simple_spec_init_c *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   206
 *    subrange_spec_init_c *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   207
 *    enumerated_spec_init_c *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
// SYM_REF2(var1_init_decl_c, var1_list, spec_init)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   210
    void *visit(var1_init_decl_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   211
      current_type_decl = symbol->spec_init;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   212
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   213
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
/* var1_list ',' variable_name */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
// SYM_LIST(var1_list_c)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
    void *visit(var1_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   218
      list_c *list = symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
      for(int i = 0; i < list->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
        if (compare_identifiers(list->elements[i], search_name) == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
	  /* by now, current_type_decl should be != NULL */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
          return current_type_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   226
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   227
/* name_list ':' function_block_type_name ASSIGN structure_initialization */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   228
/* structure_initialization -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   229
    void *visit(fb_name_decl_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   230
      current_type_decl = symbol->function_block_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   231
      return symbol->fb_name_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   232
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   233
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   234
/* name_list ',' fb_name */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   235
    void *visit(fb_name_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   236
      list_c *list = symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   237
      for(int i = 0; i < list->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   238
        if (compare_identifiers(list->elements[i], search_name) == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   239
	  /* by now, current_fb_declaration should be != NULL */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   240
          return current_type_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   241
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   242
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   243
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   244
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   245
/* var1_list ':' array_spec_init */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   246
// SYM_REF2(array_var_init_decl_c, var1_list, array_spec_init)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   247
    void *visit(array_var_init_decl_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   248
      current_type_decl = symbol->array_spec_init;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   249
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   250
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   251
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   252
/*  var1_list ':' initialized_structure */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   253
// SYM_REF2(structured_var_init_decl_c, var1_list, initialized_structure)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   254
    void *visit(structured_var_init_decl_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   255
      current_type_decl = symbol->initialized_structure;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   256
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   257
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   258
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   259
/*  var1_list ':' array_specification */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   260
// SYM_REF2(array_var_declaration_c, var1_list, array_specification)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
    void *visit(array_var_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
      current_type_decl = symbol->array_specification;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   264
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
/*  var1_list ':' structure_type_name */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
// SYM_REF2(structured_var_declaration_c, var1_list, structure_type_name)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
    void *visit(structured_var_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
      current_type_decl = symbol->structure_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   271
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   272
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   273
/*  [variable_name] location ':' located_var_spec_init */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   274
/* variable_name -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   275
// SYM_REF4(located_var_decl_c, variable_name, location, located_var_spec_init, unused)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   276
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   277
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   278
/*  global_var_name ':' (simple_specification|subrange_specification|enumerated_specification|array_specification|prev_declared_structure_type_name|function_block_type_name */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   279
// SYM_REF2(external_declaration_c, global_var_name, specification)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   280
    void *visit(external_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   281
      if (compare_identifiers(symbol->global_var_name, search_name) == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   282
          return symbol->specification;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   283
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   284
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
/*| global_var_spec ':' [located_var_spec_init|function_block_type_name] */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
/* type_specification ->may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   288
// SYM_REF2(global_var_decl_c, global_var_spec, type_specification)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
    void *visit(global_var_decl_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
      if (symbol->type_specification != NULL) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
        current_type_decl = symbol->type_specification;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
        return symbol->global_var_spec->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   293
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   294
      else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
        return NULL;
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
/*| global_var_name location */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   299
//SYM_REF2(global_var_spec_c, global_var_name, location)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
    void *visit(global_var_spec_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   301
      if (symbol->global_var_name != NULL && compare_identifiers(symbol->global_var_name, search_name) == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
          return current_type_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
      else 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
        return symbol->location->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   307
/*| global_var_list ',' global_var_name */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   308
//SYM_LIST(global_var_list_c)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   309
    void *visit(global_var_list_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   310
      list_c *list = symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   311
      for(int i = 0; i < list->n; i++) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   312
        if (compare_identifiers(list->elements[i], search_name) == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313
          /* by now, current_type_decl should be != NULL */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   314
          return current_type_decl;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   315
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   316
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   317
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   318
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
/*  [variable_name] location ':' located_var_spec_init */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   320
/* variable_name -> may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   321
//SYM_REF4(located_var_decl_c, variable_name, location, located_var_spec_init, unused)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   322
    void *visit(located_var_decl_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   323
      if (symbol->variable_name != NULL && compare_identifiers(symbol->variable_name, search_name) == 0) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   324
        return symbol->located_var_spec_init;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   325
      }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   326
      else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   327
        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   328
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   329
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   330
/*| global_var_spec ':' [located_var_spec_init|function_block_type_name] */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   331
/* type_specification ->may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   332
// SYM_REF2(global_var_decl_c, global_var_spec, type_specification)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   333
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   334
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   335
/*| global_var_name location */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   336
// SYM_REF2(global_var_spec_c, global_var_name, location)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   337
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   338
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   339
/*  AT direct_variable */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   340
// SYM_REF2(location_c, direct_variable, unused)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   341
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   342
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   343
/*| global_var_list ',' global_var_name */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   344
// SYM_LIST(global_var_list_c)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   345
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   346
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   347
/*  var1_list ':' single_byte_string_spec */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   348
// SYM_REF2(single_byte_string_var_declaration_c, var1_list, single_byte_string_spec)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   349
    void *visit(single_byte_string_var_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   350
      current_type_decl = symbol->single_byte_string_spec;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   351
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   352
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   353
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   354
/*  STRING ['[' integer ']'] [ASSIGN single_byte_character_string] */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   355
/* integer ->may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   356
/* single_byte_character_string ->may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   357
// SYM_REF2(single_byte_string_spec_c, integer, single_byte_character_string)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   358
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   359
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   360
/*  var1_list ':' double_byte_string_spec */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   361
// SYM_REF2(double_byte_string_var_declaration_c, var1_list, double_byte_string_spec)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   362
    void *visit(double_byte_string_var_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   363
      current_type_decl = symbol->double_byte_string_spec;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   364
      return symbol->var1_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   365
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   366
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   367
/*  WSTRING ['[' integer ']'] [ASSIGN double_byte_character_string] */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   368
/* integer ->may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   369
/* double_byte_character_string ->may be NULL ! */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   370
// SYM_REF2(double_byte_string_spec_c, integer, double_byte_character_string)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   371
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   372
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   373
/*  variable_name incompl_location ':' var_spec */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   374
// SYM_REF4(incompl_located_var_decl_c, variable_name, incompl_location, var_spec, unused)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   375
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   376
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   377
/*  AT incompl_location_token */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   378
// SYM_TOKEN(incompl_location_c)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   379
// TODO!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   380
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   381
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   382
/**************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   383
/* B.1.5 - Program organization units */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   384
/**************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   385
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   386
/* B 1.5.1 - Functions */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   387
/***********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   388
// SYM_REF4(function_declaration_c, derived_function_name, type_name, var_declarations_list, function_body)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   389
    void *visit(function_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   390
      /* functions have a variable named after themselves, to store
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   391
       * the variable that will be returned!!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   392
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   393
      if (compare_identifiers(symbol->derived_function_name, search_name) == 0)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   394
          return symbol->type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   395
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   396
      /* no need to search through all the body, so we only
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   397
       * visit the variable declarations...!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   399
      return symbol->var_declarations_list->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   400
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   401
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   402
/*****************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   403
/* B 1.5.2 - Function Blocks */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
/*****************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   405
    void *visit(function_block_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
      /* no need to search through all the body, so we only
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
       * visit the variable declarations...!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
      return symbol->var_declarations->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   410
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   411
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   412
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
/* B 1.5.3 - Programs */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   414
/**********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   415
    void *visit(program_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
      /* no need to search through all the body, so we only
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
       * visit the variable declarations...!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
      return symbol->var_declarations->accept(*this);
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.7 Configuration elements */
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
CONFIGURATION configuration_name
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   429
   optional_global_var_declarations
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
   (resource_declaration_list | single_resource_declaration)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
   optional_access_declarations
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
   optional_instance_specific_initializations
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
END_CONFIGURATION
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_REF6(configuration_declaration_c, configuration_name, global_var_declarations, resource_declarations, access_declarations, instance_specific_initializations, unused)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   437
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
    void *visit(configuration_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   439
      /* no need to search through all the configuration, so we only
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   440
       * visit the global variable declarations...!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   441
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   442
      if (symbol->global_var_declarations != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   443
        return symbol->global_var_declarations->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   444
      else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   445
        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   446
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   447
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   448
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   449
RESOURCE resource_name ON resource_type_name
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   450
   optional_global_var_declarations
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
   single_resource_declaration
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   452
END_RESOURCE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   454
// SYM_REF4(resource_declaration_c, resource_name, resource_type_name, global_var_declarations, resource_declaration)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   455
    void *visit(resource_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   456
      /* no need to search through all the resource, so we only
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   457
       * visit the global variable declarations...!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   458
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   459
      if (symbol->global_var_declarations != NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   460
        return symbol->global_var_declarations->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   461
      else
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   462
        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   463
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   464
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
/* task_configuration_list program_configuration_list */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
// SYM_REF2(single_resource_declaration_c, task_configuration_list, program_configuration_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   467
    void *visit(single_resource_declaration_c *symbol) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   468
      /* no need to search through all the resource,
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   469
       * and there is no global variable declarations...!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   470
       */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   471
      return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   472
    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   473
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   474
#if 0
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   475
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   476
/* B 1.4 - Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   477
/*********************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   478
SYM_REF2(symbolic_variable_c, var_name, unused)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   479
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   480
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   481
/* B.1.4.1   Directly Represented Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
/********************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   483
SYM_TOKEN(direct_variable_c)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   484
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   485
/*************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   486
/* B.1.4.2   Multi-element Variables */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
/*************************************/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   488
/*  subscripted_variable '[' subscript_list ']' */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   489
SYM_REF2(array_variable_c, subscripted_variable, subscript_list)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   490
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   491
/* subscript_list ',' subscript */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
SYM_LIST(subscript_list_c)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   494
/*  record_variable '.' field_selector */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
/*  WARNING: input and/or output variables of function blocks
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
 *           may be accessed as fields of a tructured variable!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   497
 *           Code handling a structured_variable_c must take
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
 *           this into account!
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   500
SYM_REF2(structured_variable_c, record_variable, field_selector)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   503
#endif
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
};
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   505