stage4/generate_c/il_code_gen.c
author lbessard
Wed, 24 Oct 2007 17:39:51 +0200
changeset 70 e1f0ebd2d9ec
child 149 05ca171a3d57
permissions -rw-r--r--
Change generate_cc to generate_c
70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     1
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     2
 * (c) 2003 Mario de Sousa
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     3
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     4
 * Offered to the public under the terms of the GNU General Public License
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     5
 * as published by the Free Software Foundation; either version 2 of the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     6
 * License, or (at your option) any later version.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     7
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     8
 * This program is distributed in the hope that it will be useful, but
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
     9
 * WITHOUT ANY WARRANTY; without even the implied warranty of
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    10
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    11
 * Public License for more details.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    12
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    13
 * This code is made available on the understanding that it will not be
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    14
 * used in safety-critical situations without a full and competent review.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    15
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    16
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    17
/*
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    18
 * An IEC 61131-3 IL and ST compiler.
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    19
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    20
 * Based on the
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    21
 * FINAL DRAFT - IEC 61131-3, 2nd Ed. (2001-12-10)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    22
 *
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    23
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    24
 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    25
 
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    26
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    27
 * IEC 61131-3 standard function lib
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    28
 * generated code, do not edit by hand
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    29
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    30
switch(current_function_type){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    31
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    32
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    33
 *BOOL_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    34
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    35
    case function_bool_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    36
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    37
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    38
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    39
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    40
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    41
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    42
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    43
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    44
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    45
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    46
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    47
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    48
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    49
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    50
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    51
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    52
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    53
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    54
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    55
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    56
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    57
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    58
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    59
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    60
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    61
    }/*function_bool_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    62
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    63
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    64
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    65
 *BOOL_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    66
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    67
    case function_bool_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    68
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    69
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    70
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    71
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    72
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    73
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    74
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    75
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    76
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    77
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    78
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    79
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    80
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    81
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    82
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    83
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    84
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    85
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    86
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    87
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    88
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    89
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    90
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    91
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    92
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    93
    }/*function_bool_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    94
    break;
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
 *BOOL_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    98
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
    99
    case function_bool_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   100
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   101
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   102
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   103
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   104
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   105
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   106
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   107
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   108
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   109
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   110
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   111
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   112
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   113
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   114
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   115
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   116
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   117
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   118
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   119
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   120
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   121
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   122
            ERROR;
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
    }/*function_bool_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   126
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   127
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   128
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   129
 *BOOL_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   130
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   131
    case function_bool_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   132
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   133
        symbol_c *last_type_symbol = NULL;
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
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   137
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   138
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   139
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   140
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   141
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   142
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   143
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   144
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   145
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   146
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   147
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   148
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   149
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   150
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   151
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   152
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   153
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   154
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   155
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   156
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   157
    }/*function_bool_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   158
    break;
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
 *BOOL_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   162
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   163
    case function_bool_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   164
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   165
        symbol_c *last_type_symbol = NULL;
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
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   169
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   170
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   171
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   172
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   173
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   174
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
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
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   178
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   179
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   180
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   181
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   182
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   183
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   184
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   185
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   186
            ERROR;
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
    }/*function_bool_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   190
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   191
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   192
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   193
 *BOOL_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   194
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   195
    case function_bool_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   196
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   197
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   198
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   199
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   200
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   201
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   202
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   203
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   204
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   205
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   206
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   207
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   208
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   209
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   210
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   211
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   212
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   213
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   214
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   215
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   216
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   217
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   218
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   219
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   220
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   221
    }/*function_bool_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   222
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   223
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   224
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   225
 *BOOL_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   226
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   227
    case function_bool_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   228
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   229
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   230
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   231
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   232
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   233
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   234
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   235
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   236
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   237
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   238
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   239
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   240
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   241
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   242
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   243
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   244
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   245
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   246
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   247
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   248
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   249
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   250
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   251
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   252
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   253
    }/*function_bool_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   254
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   255
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   256
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   257
 *BOOL_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   258
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   259
    case function_bool_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   260
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   261
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   262
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   263
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   264
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   265
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   266
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   267
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   268
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   269
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   270
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
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
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   274
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   275
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   276
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   277
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   278
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   279
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   280
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   281
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   282
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   283
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   284
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   285
    }/*function_bool_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   286
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   287
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   288
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   289
 *BOOL_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   290
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   291
    case function_bool_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   292
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   293
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   294
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   295
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   296
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   297
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   298
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   299
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   300
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   301
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   302
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   303
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   304
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   305
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   306
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   307
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   308
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   309
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   310
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   311
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   312
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   313
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   314
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   315
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   316
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   317
    }/*function_bool_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   318
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   319
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   320
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   321
 *BOOL_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   322
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   323
    case function_bool_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   324
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   325
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   326
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   327
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   328
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   329
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   330
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   331
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   332
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   333
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   334
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   335
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   336
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   337
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   338
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   339
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   340
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   341
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   342
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   343
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   344
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   345
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   346
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   347
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   348
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   349
    }/*function_bool_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   350
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   351
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   352
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   353
 *BOOL_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   354
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   355
    case function_bool_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   356
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   357
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   358
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   359
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   360
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   361
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   362
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   363
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   364
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   365
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   366
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   367
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   368
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   369
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   370
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   371
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   372
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   373
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   374
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   375
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   376
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   377
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   378
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   379
            ERROR;
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
    }/*function_bool_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   383
    break;
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
 *BOOL_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   387
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   388
    case function_bool_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   389
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   390
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   391
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   392
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   393
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   394
            symbol_c *IN_param_value = &this->default_variable_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
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   397
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   398
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   399
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
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
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   403
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   404
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   405
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   406
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   407
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   408
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   409
                
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
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   413
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   414
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   415
    }/*function_bool_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   416
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   417
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   418
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   419
 *BOOL_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   420
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   421
    case function_bool_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   422
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   423
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   424
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   425
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   426
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   427
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   428
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   429
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   430
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   431
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   432
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   433
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   434
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   435
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   436
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   437
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   438
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   439
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   440
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   441
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   442
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   443
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   444
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   445
            ERROR;
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
    }/*function_bool_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   449
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   450
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   451
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   452
 *BOOL_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   453
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   454
    case function_bool_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   455
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   456
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   457
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   458
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   459
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   460
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   461
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   462
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   463
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   464
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   465
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   466
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   467
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   468
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   469
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   470
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   471
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   472
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   473
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   474
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   475
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   476
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   477
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   478
            ERROR;
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
    }/*function_bool_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   482
    break;
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
 *BOOL_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   486
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   487
    case function_bool_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   488
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   489
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   490
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   491
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   492
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   493
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   494
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   495
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   496
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   497
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   498
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   499
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   500
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   501
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   502
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   503
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   504
                s4o.print(")__bool_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   505
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   506
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   507
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   508
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   509
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   510
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   511
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   512
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   513
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   514
    }/*function_bool_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   515
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   516
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   517
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   518
 *BOOL_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   519
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   520
    case function_bool_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   521
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   522
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   523
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   524
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   525
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   526
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   527
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   528
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   529
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   530
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   531
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   532
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   533
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   534
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   535
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   536
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   537
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   538
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   539
                return NULL;
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
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   543
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   544
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   545
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   546
    }/*function_bool_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   547
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   548
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   549
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   550
 *BOOL_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   551
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   552
    case function_bool_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   553
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   554
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   555
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   556
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   557
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   558
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   559
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   560
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   561
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   562
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   563
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   564
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   565
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   566
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   567
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   568
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   569
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   570
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   571
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   572
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   573
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   574
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   575
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   576
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   577
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   578
    }/*function_bool_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   579
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   580
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   581
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   582
 *BOOL_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   583
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   584
    case function_bool_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   585
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   586
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   587
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   588
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   589
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   590
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   591
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   592
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   593
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   594
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   595
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
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
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   599
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   600
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   601
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   602
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   603
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   604
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   605
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   606
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   607
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   608
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   609
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   610
    }/*function_bool_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   611
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   612
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   613
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   614
 *BOOL_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   615
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   616
    case function_bool_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   617
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   618
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   619
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   620
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   621
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   622
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   623
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   624
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   625
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   626
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   627
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   628
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   629
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   630
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   631
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   632
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   633
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   634
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   635
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   636
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   637
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   638
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   639
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   640
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   641
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   642
    }/*function_bool_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   643
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   644
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   645
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   646
 *SINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   647
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   648
    case function_sint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   649
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   650
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   651
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   652
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   653
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   654
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   655
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   656
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   657
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   658
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   659
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   660
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   661
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   662
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   663
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   664
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   665
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   666
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   667
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   668
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   669
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   670
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   671
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   672
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   673
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   674
    }/*function_sint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   675
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   676
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   677
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   678
 *SINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   679
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   680
    case function_sint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   681
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   682
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   683
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   684
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   685
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   686
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   687
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   688
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   689
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   690
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   691
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   692
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   693
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   694
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   695
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   696
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   697
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   698
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   699
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   700
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   701
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   702
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   703
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   704
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   705
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   706
    }/*function_sint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   707
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   708
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   709
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   710
 *SINT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   711
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   712
    case function_sint_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   713
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   714
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   715
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   716
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   717
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   718
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   719
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   720
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   721
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   722
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   723
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   724
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   725
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   726
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   727
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   728
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   729
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   730
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   731
                return NULL;
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
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   736
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   737
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   738
    }/*function_sint_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   739
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   740
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   741
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   742
 *SINT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   743
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   744
    case function_sint_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   745
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   746
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   747
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   748
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   749
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   750
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   751
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   752
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   753
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   754
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   755
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   756
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   757
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   758
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   759
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   760
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   761
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   762
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   763
                return NULL;
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
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   767
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   768
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   769
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   770
    }/*function_sint_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   771
    break;
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
 *SINT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   775
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   776
    case function_sint_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   777
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   778
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   779
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   780
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   781
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   782
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   783
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   784
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   785
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   786
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   787
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   788
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   789
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   790
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   791
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   792
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   793
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   794
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   795
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   796
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   797
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   798
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   799
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   800
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   801
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   802
    }/*function_sint_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   803
    break;
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
 *SINT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   807
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   808
    case function_sint_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   809
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   810
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   811
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   812
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   813
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   814
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   815
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   816
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   817
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   818
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   819
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   820
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   821
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   822
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   823
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   824
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   825
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   826
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   827
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   828
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   829
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   830
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   831
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   832
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   833
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   834
    }/*function_sint_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   835
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   836
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   837
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   838
 *SINT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   839
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   840
    case function_sint_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   841
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   842
        symbol_c *last_type_symbol = NULL;
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
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   846
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   847
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   848
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   849
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   850
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   851
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
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
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   855
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   856
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   857
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   858
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   859
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   860
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   861
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   862
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   863
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   864
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   865
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   866
    }/*function_sint_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   867
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   868
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   869
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   870
 *SINT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   871
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   872
    case function_sint_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   873
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   874
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   875
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   876
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   877
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   878
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   879
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   880
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   881
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   882
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   883
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   884
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   885
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   886
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   887
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   888
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   889
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   890
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   891
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   892
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   893
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   894
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   895
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   896
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   897
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   898
    }/*function_sint_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   899
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   900
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   901
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   902
 *SINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   903
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   904
    case function_sint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   905
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   906
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   907
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   908
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   909
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   910
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   911
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   912
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   913
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   914
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   915
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   916
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   917
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   918
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   919
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   920
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   921
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   922
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   923
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   924
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   925
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   926
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   927
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   928
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   929
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   930
    }/*function_sint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   931
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   932
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   933
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   934
 *SINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   935
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   936
    case function_sint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   937
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   938
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   939
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   940
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   941
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   942
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   943
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   944
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   945
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   946
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   947
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   948
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   949
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   950
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   951
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   952
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   953
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   954
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   955
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   956
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   957
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   958
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   959
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   960
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   961
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   962
    }/*function_sint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   963
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   964
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   965
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   966
 *SINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   967
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   968
    case function_sint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   969
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   970
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   971
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   972
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   973
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   974
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   975
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   976
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   977
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   978
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   979
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   980
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   981
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   982
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   983
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   984
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   985
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   986
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   987
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   988
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   989
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   990
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   991
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   992
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   993
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   994
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   995
    }/*function_sint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   996
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   997
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   998
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
   999
 *SINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1000
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1001
    case function_sint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1002
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1003
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1004
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1005
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1006
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1007
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1008
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1009
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1010
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1011
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1012
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1013
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1014
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1015
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1016
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1017
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1018
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1019
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1020
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1021
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1022
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1023
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1024
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1025
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1026
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1027
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1028
    }/*function_sint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1029
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1030
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1031
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1032
 *SINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1033
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1034
    case function_sint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1035
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1036
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1037
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1038
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1039
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1040
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1041
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1042
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1043
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1044
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1045
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1046
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1047
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1048
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1049
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1050
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1051
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1052
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1053
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1054
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1055
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1056
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1057
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1058
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1059
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1060
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1061
    }/*function_sint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1062
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1063
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1064
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1065
 *SINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1066
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1067
    case function_sint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1068
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1069
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1070
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1071
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1072
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1073
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1074
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1075
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1076
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1077
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1078
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1079
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1080
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1081
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1082
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1083
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1084
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1085
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1086
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1087
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1088
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1089
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1090
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1091
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1092
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1093
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1094
    }/*function_sint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1095
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1096
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1097
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1098
 *SINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1099
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1100
    case function_sint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1101
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1102
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1103
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1104
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1105
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1106
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1107
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1108
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1109
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1110
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1111
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1112
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1113
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1114
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1115
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1116
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1117
                s4o.print(")__sint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1118
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1119
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1120
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1121
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1122
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1123
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1124
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1125
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1126
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1127
    }/*function_sint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1128
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1129
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1130
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1131
 *SINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1132
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1133
    case function_sint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1134
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1135
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1136
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1137
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1138
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1139
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1140
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1141
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1142
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1143
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1144
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1145
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1146
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1147
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1148
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1149
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1150
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1151
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1152
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1153
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1154
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1155
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1156
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1157
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1158
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1159
    }/*function_sint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1160
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1161
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1162
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1163
 *SINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1164
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1165
    case function_sint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1166
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1167
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1168
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1169
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1170
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1171
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1172
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1173
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1174
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1175
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1176
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1177
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1178
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1179
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1180
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1181
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1182
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1183
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1184
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1185
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1186
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1187
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1188
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1189
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1190
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1191
    }/*function_sint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1192
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1193
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1194
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1195
 *SINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1196
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1197
    case function_sint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1198
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1199
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1200
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1201
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1202
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1203
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1204
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1205
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1206
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1207
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1208
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1209
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1210
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1211
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1212
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1213
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1214
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1215
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1216
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1217
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1218
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1219
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1220
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1221
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1222
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1223
    }/*function_sint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1224
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1225
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1226
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1227
 *SINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1228
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1229
    case function_sint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1230
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1231
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1232
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1233
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1234
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1235
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1236
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1237
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1238
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1239
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1240
            if(search_expression_type->is_same_type(&search_constant_type_c::sint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1241
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1242
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1243
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1244
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1245
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1246
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1247
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1248
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1249
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1250
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1251
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1252
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1253
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1254
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1255
    }/*function_sint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1256
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1257
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1258
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1259
 *INT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1260
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1261
    case function_int_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1262
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1263
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1264
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1265
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1266
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1267
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1268
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1269
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1270
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1271
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1272
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1273
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1274
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1275
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1276
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1277
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1278
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1279
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1280
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1281
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1282
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1283
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1284
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1285
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1286
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1287
    }/*function_int_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1288
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1289
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1290
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1291
 *INT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1292
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1293
    case function_int_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1294
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1295
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1296
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1297
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1298
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1299
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1300
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1301
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1302
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1303
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1304
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1305
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1306
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1307
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1308
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1309
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1310
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1311
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1312
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1313
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1314
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1315
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1316
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1317
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1318
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1319
    }/*function_int_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1320
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1321
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1322
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1323
 *INT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1324
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1325
    case function_int_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1326
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1327
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1328
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1329
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1330
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1331
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1333
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1334
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1335
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1336
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1337
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1338
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1339
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1340
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1341
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1342
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1343
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1344
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1345
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1346
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1347
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1348
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1349
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1350
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1351
    }/*function_int_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1352
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1353
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1354
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1355
 *INT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1356
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1357
    case function_int_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1358
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1359
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1360
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1361
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1362
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1363
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1364
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1365
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1366
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1367
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1368
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1369
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1370
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1371
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1372
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1373
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1374
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1375
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1376
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1377
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1378
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1379
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1380
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1381
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1382
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1383
    }/*function_int_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1384
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1385
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1386
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1387
 *INT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1388
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1389
    case function_int_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1390
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1391
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1392
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1393
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1394
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1395
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1396
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1397
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1398
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1399
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1400
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1401
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1402
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1403
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1404
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1405
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1406
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1407
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1408
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1409
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1410
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1411
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1412
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1413
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1414
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1415
    }/*function_int_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1416
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1417
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1418
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1419
 *INT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1420
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1421
    case function_int_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1422
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1423
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1424
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1425
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1426
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1427
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1428
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1429
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1430
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1431
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1432
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1433
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1434
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1435
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1436
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1437
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1438
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1439
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1440
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1441
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1442
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1443
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1444
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1445
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1446
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1447
    }/*function_int_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1448
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1449
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1450
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1451
 *INT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1452
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1453
    case function_int_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1454
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1455
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1456
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1457
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1458
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1459
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1460
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1461
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1462
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1463
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1464
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1465
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1466
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1467
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1468
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1469
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1470
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1471
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1472
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1473
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1474
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1475
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1476
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1477
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1478
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1479
    }/*function_int_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1480
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1481
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1482
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1483
 *INT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1484
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1485
    case function_int_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1486
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1487
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1488
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1489
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1490
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1491
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1492
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1493
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1494
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1495
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1496
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1497
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1498
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1499
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1500
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1501
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1502
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1503
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1504
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1505
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1506
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1507
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1508
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1509
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1510
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1511
    }/*function_int_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1512
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1513
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1514
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1515
 *INT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1516
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1517
    case function_int_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1518
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1519
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1520
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1521
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1522
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1523
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1524
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1525
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1526
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1527
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1528
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1529
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1530
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1531
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1532
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1533
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1534
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1535
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1536
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1537
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1538
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1539
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1540
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1541
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1542
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1543
    }/*function_int_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1544
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1545
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1546
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1547
 *INT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1548
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1549
    case function_int_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1550
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1551
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1552
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1553
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1554
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1555
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1556
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1557
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1558
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1559
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1560
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1561
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1562
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1563
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1564
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1565
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1566
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1567
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1568
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1569
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1570
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1571
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1572
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1573
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1574
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1575
    }/*function_int_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1576
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1577
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1578
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1579
 *INT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1580
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1581
    case function_int_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1582
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1583
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1584
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1585
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1586
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1587
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1588
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1589
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1590
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1591
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1592
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1593
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1594
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1595
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1596
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1597
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1598
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1599
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1600
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1601
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1602
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1603
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1604
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1605
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1606
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1607
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1608
    }/*function_int_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1609
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1610
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1611
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1612
 *INT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1613
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1614
    case function_int_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1615
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1616
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1617
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1618
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1619
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1620
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1621
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1622
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1623
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1624
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1625
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1626
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1627
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1628
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1629
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1630
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1631
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1632
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1633
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1634
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1635
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1636
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1637
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1638
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1639
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1640
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1641
    }/*function_int_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1642
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1643
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1644
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1645
 *INT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1646
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1647
    case function_int_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1648
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1649
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1650
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1651
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1652
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1653
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1654
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1655
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1656
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1657
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1658
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1659
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1660
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1661
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1662
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1663
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1664
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1665
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1666
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1667
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1668
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1669
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1670
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1671
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1672
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1673
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1674
    }/*function_int_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1675
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1676
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1677
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1678
 *INT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1679
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1680
    case function_int_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1681
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1682
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1683
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1684
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1685
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1686
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1687
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1688
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1689
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1690
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1691
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1692
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1693
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1694
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1695
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1696
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1697
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1698
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1699
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1700
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1701
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1702
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1703
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1704
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1705
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1706
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1707
    }/*function_int_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1708
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1709
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1710
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1711
 *INT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1712
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1713
    case function_int_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1714
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1715
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1716
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1717
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1718
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1719
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1720
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1721
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1722
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1723
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1724
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1725
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1726
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1727
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1728
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1729
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1730
                s4o.print(")__sint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1731
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1732
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1733
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1734
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1735
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1736
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1737
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1738
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1739
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1740
    }/*function_int_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1741
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1742
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1743
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1744
 *INT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1745
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1746
    case function_int_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1747
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1748
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1749
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1750
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1751
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1752
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1753
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1754
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1755
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1756
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1757
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1758
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1759
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1760
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1761
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1762
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1763
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1764
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1765
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1766
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1767
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1768
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1769
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1770
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1771
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1772
    }/*function_int_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1773
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1774
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1775
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1776
 *INT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1777
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1778
    case function_int_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1779
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1780
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1781
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1782
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1783
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1784
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1785
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1786
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1787
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1788
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1789
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1790
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1791
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1792
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1793
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1794
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1795
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1796
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1797
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1798
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1799
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1800
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1801
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1802
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1803
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1804
    }/*function_int_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1805
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1806
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1807
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1808
 *INT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1809
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1810
    case function_int_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1811
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1812
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1813
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1814
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1815
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1816
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1817
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1818
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1819
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1820
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1821
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1822
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1823
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1824
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1825
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1826
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1827
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1828
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1829
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1830
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1831
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1832
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1833
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1834
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1835
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1836
    }/*function_int_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1837
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1838
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1839
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1840
 *INT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1841
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1842
    case function_int_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1843
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1844
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1845
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1846
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1847
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1848
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1849
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1850
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1851
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1852
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1853
            if(search_expression_type->is_same_type(&search_constant_type_c::int_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1854
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1855
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1856
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1857
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1858
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1859
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1860
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1861
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1862
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1863
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1864
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1865
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1866
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1867
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1868
    }/*function_int_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1869
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1870
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1871
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1872
 *DINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1873
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1874
    case function_dint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1875
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1876
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1877
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1878
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1879
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1880
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1881
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1882
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1883
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1884
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1885
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1886
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1887
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1888
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1889
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1890
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1891
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1892
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1893
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1894
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1895
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1896
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1897
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1898
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1899
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1900
    }/*function_dint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1901
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1902
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1903
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1904
 *DINT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1905
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1906
    case function_dint_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1907
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1908
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1909
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1910
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1911
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1912
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1913
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1914
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1915
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1916
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1917
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1918
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1919
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1920
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1921
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1922
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1923
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1924
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1925
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1926
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1927
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1928
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1929
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1930
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1931
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1932
    }/*function_dint_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1933
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1934
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1935
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1936
 *DINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1937
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1938
    case function_dint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1939
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1940
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1941
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1942
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1943
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1944
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1945
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1946
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1947
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1948
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1949
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1950
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1951
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1952
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1953
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1954
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1955
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1956
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1957
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1958
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1959
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1960
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1961
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1962
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1963
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1964
    }/*function_dint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1965
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1966
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1967
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1968
 *DINT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1969
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1970
    case function_dint_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1971
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1972
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1973
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1974
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1975
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1976
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1977
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1978
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1979
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1980
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1981
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1982
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1983
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1984
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1985
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1986
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1987
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1988
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1989
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1990
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1991
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1992
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1993
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1994
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1995
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1996
    }/*function_dint_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1997
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1998
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  1999
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2000
 *DINT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2001
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2002
    case function_dint_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2003
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2004
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2005
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2006
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2007
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2008
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2009
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2010
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2011
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2012
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2013
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2014
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2015
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2016
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2017
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2018
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2019
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2020
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2021
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2022
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2023
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2024
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2025
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2026
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2027
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2028
    }/*function_dint_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2029
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2030
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2031
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2032
 *DINT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2033
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2034
    case function_dint_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2035
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2036
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2037
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2038
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2039
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2040
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2041
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2042
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2043
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2044
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2045
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2046
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2047
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2048
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2049
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2050
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2051
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2052
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2053
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2054
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2055
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2056
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2057
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2058
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2059
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2060
    }/*function_dint_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2061
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2062
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2063
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2064
 *DINT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2065
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2066
    case function_dint_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2067
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2068
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2069
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2070
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2071
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2072
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2073
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2074
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2075
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2076
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2077
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2078
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2079
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2080
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2081
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2082
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2083
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2084
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2085
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2086
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2087
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2088
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2089
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2090
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2091
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2092
    }/*function_dint_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2093
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2094
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2095
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2096
 *DINT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2097
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2098
    case function_dint_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2099
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2100
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2101
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2102
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2103
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2104
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2105
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2106
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2107
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2108
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2109
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2110
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2111
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2112
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2113
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2114
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2115
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2116
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2117
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2118
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2119
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2120
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2121
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2122
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2123
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2124
    }/*function_dint_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2125
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2126
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2127
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2128
 *DINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2129
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2130
    case function_dint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2131
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2132
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2133
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2134
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2135
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2136
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2137
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2138
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2139
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2140
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2141
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2142
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2143
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2144
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2145
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2146
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2147
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2148
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2149
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2150
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2151
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2152
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2153
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2154
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2155
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2156
    }/*function_dint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2157
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2158
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2159
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2160
 *DINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2161
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2162
    case function_dint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2163
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2164
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2165
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2166
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2167
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2168
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2169
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2170
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2171
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2172
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2173
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2174
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2175
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2176
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2177
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2178
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2179
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2180
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2181
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2182
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2183
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2184
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2185
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2186
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2187
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2188
    }/*function_dint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2189
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2190
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2191
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2192
 *DINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2193
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2194
    case function_dint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2195
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2196
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2197
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2198
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2199
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2200
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2201
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2202
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2203
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2204
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2205
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2206
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2207
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2208
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2209
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2210
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2211
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2212
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2213
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2214
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2215
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2216
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2217
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2218
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2219
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2220
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2221
    }/*function_dint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2222
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2223
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2224
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2225
 *DINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2226
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2227
    case function_dint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2228
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2229
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2230
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2231
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2232
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2233
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2234
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2235
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2236
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2237
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2238
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2239
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2240
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2241
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2242
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2243
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2244
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2245
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2246
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2247
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2248
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2249
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2250
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2251
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2252
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2253
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2254
    }/*function_dint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2255
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2256
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2257
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2258
 *DINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2259
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2260
    case function_dint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2261
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2262
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2263
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2264
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2265
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2266
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2267
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2268
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2269
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2270
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2271
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2272
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2273
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2274
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2275
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2276
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2277
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2278
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2279
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2280
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2281
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2282
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2283
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2284
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2285
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2286
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2287
    }/*function_dint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2288
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2289
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2290
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2291
 *DINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2292
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2293
    case function_dint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2294
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2295
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2296
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2297
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2298
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2299
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2300
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2301
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2302
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2303
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2304
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2305
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2306
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2307
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2308
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2309
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2310
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2311
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2312
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2313
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2314
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2315
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2316
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2317
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2318
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2319
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2320
    }/*function_dint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2321
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2322
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2323
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2324
 *DINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2325
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2326
    case function_dint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2327
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2328
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2329
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2330
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2331
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2332
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2333
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2334
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2335
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2336
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2337
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2338
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2339
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2340
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2341
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2342
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2343
                s4o.print(")__sint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2344
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2345
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2346
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2347
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2348
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2349
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2350
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2351
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2352
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2353
    }/*function_dint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2354
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2355
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2356
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2357
 *DINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2358
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2359
    case function_dint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2360
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2361
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2362
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2363
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2364
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2365
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2366
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2367
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2368
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2369
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2370
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2371
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2372
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2373
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2374
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2375
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2376
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2377
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2378
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2379
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2380
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2381
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2382
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2383
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2384
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2385
    }/*function_dint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2386
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2387
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2388
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2389
 *DINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2390
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2391
    case function_dint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2392
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2393
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2394
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2395
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2396
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2397
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2398
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2399
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2400
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2401
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2402
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2403
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2404
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2405
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2406
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2407
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2408
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2409
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2410
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2411
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2412
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2413
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2414
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2415
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2416
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2417
    }/*function_dint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2418
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2420
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2421
 *DINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2422
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2423
    case function_dint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2424
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2425
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2426
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2427
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2428
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2429
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2430
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2431
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2432
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2433
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2434
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2435
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2436
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2437
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2438
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2439
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2440
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2441
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2442
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2443
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2444
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2445
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2446
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2447
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2448
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2449
    }/*function_dint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2450
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2451
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2452
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2453
 *DINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2454
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2455
    case function_dint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2456
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2457
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2458
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2459
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2460
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2461
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2462
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2463
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2464
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2465
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2466
            if(search_expression_type->is_same_type(&search_constant_type_c::dint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2467
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2468
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2469
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2470
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2471
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2472
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2473
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2474
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2475
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2476
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2477
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2478
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2479
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2480
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2481
    }/*function_dint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2482
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2483
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2484
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2485
 *LINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2486
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2487
    case function_lint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2488
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2489
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2490
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2491
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2492
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2493
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2494
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2495
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2496
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2497
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2498
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2499
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2500
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2501
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2502
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2503
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2504
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2505
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2506
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2507
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2508
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2509
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2510
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2511
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2512
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2513
    }/*function_lint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2514
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2515
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2516
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2517
 *LINT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2518
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2519
    case function_lint_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2520
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2521
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2522
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2523
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2524
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2525
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2526
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2527
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2528
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2529
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2530
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2531
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2532
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2533
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2534
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2535
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2536
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2537
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2538
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2539
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2540
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2541
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2542
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2543
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2544
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2545
    }/*function_lint_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2546
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2547
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2548
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2549
 *LINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2550
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2551
    case function_lint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2552
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2553
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2554
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2555
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2556
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2557
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2558
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2559
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2560
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2561
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2562
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2563
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2564
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2565
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2566
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2567
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2568
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2569
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2570
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2571
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2572
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2573
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2574
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2575
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2576
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2577
    }/*function_lint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2578
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2579
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2580
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2581
 *LINT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2582
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2583
    case function_lint_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2584
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2585
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2586
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2587
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2588
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2589
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2590
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2591
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2592
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2593
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2594
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2595
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2596
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2597
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2598
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2599
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2600
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2601
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2602
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2603
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2604
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2605
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2606
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2607
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2608
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2609
    }/*function_lint_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2610
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2611
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2612
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2613
 *LINT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2614
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2615
    case function_lint_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2616
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2617
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2618
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2619
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2620
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2621
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2622
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2623
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2624
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2625
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2626
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2627
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2628
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2629
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2630
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2631
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2632
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2633
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2634
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2635
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2636
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2637
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2638
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2639
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2640
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2641
    }/*function_lint_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2642
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2643
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2644
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2645
 *LINT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2646
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2647
    case function_lint_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2648
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2649
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2650
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2651
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2652
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2653
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2654
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2655
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2656
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2657
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2658
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2659
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2660
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2661
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2662
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2663
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2664
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2665
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2666
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2667
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2668
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2669
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2670
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2671
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2672
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2673
    }/*function_lint_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2674
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2675
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2676
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2677
 *LINT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2678
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2679
    case function_lint_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2680
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2681
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2682
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2683
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2684
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2685
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2686
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2687
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2688
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2689
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2690
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2691
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2692
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2693
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2694
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2695
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2696
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2697
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2698
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2699
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2700
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2701
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2702
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2703
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2704
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2705
    }/*function_lint_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2706
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2707
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2708
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2709
 *LINT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2710
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2711
    case function_lint_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2712
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2713
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2714
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2715
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2716
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2717
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2718
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2719
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2720
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2721
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2722
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2723
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2724
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2725
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2726
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2727
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2728
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2729
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2730
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2731
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2732
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2733
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2734
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2735
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2736
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2737
    }/*function_lint_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2738
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2739
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2740
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2741
 *LINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2742
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2743
    case function_lint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2744
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2745
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2746
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2747
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2748
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2749
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2750
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2751
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2752
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2753
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2754
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2755
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2756
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2757
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2758
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2759
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2760
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2761
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2762
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2763
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2764
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2765
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2766
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2767
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2768
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2769
    }/*function_lint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2770
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2771
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2772
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2773
 *LINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2774
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2775
    case function_lint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2776
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2777
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2778
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2779
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2780
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2781
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2782
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2783
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2784
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2785
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2786
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2787
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2788
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2789
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2790
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2791
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2792
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2793
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2794
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2795
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2796
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2797
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2798
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2799
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2800
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2801
    }/*function_lint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2802
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2803
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2804
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2805
 *LINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2806
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2807
    case function_lint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2808
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2809
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2810
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2811
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2812
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2813
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2814
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2815
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2816
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2817
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2818
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2819
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2820
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2821
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2822
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2823
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2824
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2825
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2826
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2827
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2828
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2829
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2830
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2831
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2832
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2833
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2834
    }/*function_lint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2835
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2836
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2837
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2838
 *LINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2839
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2840
    case function_lint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2841
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2842
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2843
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2844
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2845
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2846
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2847
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2848
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2849
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2850
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2851
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2852
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2853
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2854
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2855
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2856
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2857
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2858
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2859
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2860
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2861
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2862
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2863
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2864
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2865
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2866
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2867
    }/*function_lint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2868
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2869
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2870
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2871
 *LINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2872
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2873
    case function_lint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2874
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2875
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2876
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2877
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2878
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2879
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2880
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2881
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2882
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2883
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2884
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2885
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2886
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2887
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2888
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2889
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2890
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2891
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2892
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2893
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2894
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2895
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2896
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2897
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2898
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2899
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2900
    }/*function_lint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2901
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2902
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2903
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2904
 *LINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2905
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2906
    case function_lint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2907
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2908
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2909
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2910
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2911
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2912
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2913
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2914
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2915
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2916
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2917
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2918
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2919
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2920
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2921
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2922
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2923
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2924
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2925
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2926
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2927
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2928
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2929
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2930
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2931
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2932
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2933
    }/*function_lint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2934
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2935
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2936
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2937
 *LINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2938
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2939
    case function_lint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2940
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2941
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2942
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2943
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2944
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2945
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2946
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2947
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2948
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2949
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2950
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2951
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2952
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2953
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2954
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2955
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2956
                s4o.print(")__sint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2957
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2958
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2959
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2960
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2961
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2962
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2963
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2964
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2965
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2966
    }/*function_lint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2967
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2968
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2969
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2970
 *LINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2971
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2972
    case function_lint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2973
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2974
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2975
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2976
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2977
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2978
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2979
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2980
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2981
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2982
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2983
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2984
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2985
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2986
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2987
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2988
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2989
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2990
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2991
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2992
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2993
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2994
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2995
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2996
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2997
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2998
    }/*function_lint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  2999
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3000
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3001
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3002
 *LINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3003
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3004
    case function_lint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3005
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3006
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3007
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3008
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3009
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3010
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3011
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3012
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3013
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3014
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3015
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3016
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3017
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3018
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3019
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3020
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3021
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3022
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3023
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3024
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3025
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3026
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3027
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3028
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3029
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3030
    }/*function_lint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3031
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3032
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3033
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3034
 *LINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3035
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3036
    case function_lint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3037
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3038
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3039
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3040
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3041
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3042
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3043
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3044
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3045
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3046
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3047
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3048
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3049
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3050
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3051
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3052
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3053
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3054
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3055
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3056
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3057
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3058
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3059
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3060
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3061
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3062
    }/*function_lint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3063
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3064
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3065
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3066
 *LINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3067
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3068
    case function_lint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3069
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3070
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3071
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3072
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3073
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3074
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3075
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3076
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3077
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3078
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3079
            if(search_expression_type->is_same_type(&search_constant_type_c::lint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3080
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3081
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3082
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3083
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3084
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3085
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3086
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3087
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3088
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3089
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3090
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3091
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3092
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3093
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3094
    }/*function_lint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3095
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3096
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3097
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3098
 *USINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3099
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3100
    case function_usint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3101
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3102
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3103
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3104
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3105
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3106
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3107
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3108
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3109
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3110
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3111
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3112
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3113
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3114
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3115
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3116
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3117
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3118
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3119
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3120
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3121
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3122
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3123
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3124
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3125
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3126
    }/*function_usint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3127
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3128
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3129
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3130
 *USINT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3131
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3132
    case function_usint_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3133
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3134
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3135
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3136
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3137
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3138
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3139
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3140
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3141
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3142
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3143
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3144
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3145
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3146
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3147
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3148
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3149
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3150
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3151
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3152
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3153
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3154
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3155
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3156
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3157
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3158
    }/*function_usint_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3159
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3160
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3161
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3162
 *USINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3163
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3164
    case function_usint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3165
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3166
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3167
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3168
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3169
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3170
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3171
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3172
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3173
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3174
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3175
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3176
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3177
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3178
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3179
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3180
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3181
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3182
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3183
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3184
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3185
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3186
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3187
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3188
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3189
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3190
    }/*function_usint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3191
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3192
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3193
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3194
 *USINT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3195
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3196
    case function_usint_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3197
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3198
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3199
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3200
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3201
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3202
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3203
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3204
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3205
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3206
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3207
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3208
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3209
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3210
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3211
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3212
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3213
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3214
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3215
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3216
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3217
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3218
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3219
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3220
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3221
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3222
    }/*function_usint_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3223
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3224
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3225
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3226
 *USINT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3227
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3228
    case function_usint_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3229
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3230
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3231
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3232
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3233
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3234
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3235
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3236
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3237
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3238
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3239
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3240
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3241
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3242
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3243
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3244
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3245
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3246
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3247
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3248
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3249
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3250
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3251
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3252
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3253
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3254
    }/*function_usint_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3255
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3256
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3257
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3258
 *USINT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3259
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3260
    case function_usint_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3261
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3262
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3263
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3264
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3265
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3266
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3267
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3268
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3269
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3270
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3271
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3272
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3273
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3274
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3275
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3276
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3277
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3278
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3279
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3280
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3281
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3282
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3283
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3284
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3285
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3286
    }/*function_usint_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3287
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3288
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3289
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3290
 *USINT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3291
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3292
    case function_usint_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3293
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3294
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3295
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3296
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3297
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3298
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3299
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3300
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3301
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3302
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3303
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3304
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3305
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3306
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3307
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3308
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3309
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3310
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3311
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3312
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3313
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3314
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3315
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3316
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3317
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3318
    }/*function_usint_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3319
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3320
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3321
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3322
 *USINT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3323
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3324
    case function_usint_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3325
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3326
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3327
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3328
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3329
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3330
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3331
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3332
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3333
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3334
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3335
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3336
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3337
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3338
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3339
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3340
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3341
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3342
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3343
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3344
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3345
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3346
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3347
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3348
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3349
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3350
    }/*function_usint_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3351
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3352
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3353
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3354
 *USINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3355
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3356
    case function_usint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3357
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3358
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3359
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3360
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3361
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3362
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3363
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3364
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3365
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3366
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3367
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3368
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3369
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3370
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3371
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3372
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3373
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3374
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3375
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3376
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3377
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3378
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3379
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3380
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3381
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3382
    }/*function_usint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3383
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3384
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3385
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3386
 *USINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3387
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3388
    case function_usint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3389
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3390
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3391
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3392
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3393
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3394
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3395
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3396
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3397
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3398
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3399
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3400
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3401
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3402
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3403
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3404
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3405
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3406
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3407
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3408
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3409
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3410
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3411
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3412
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3413
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3414
    }/*function_usint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3415
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3416
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3417
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3418
 *USINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3419
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3420
    case function_usint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3421
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3422
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3423
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3424
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3425
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3426
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3427
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3428
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3429
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3430
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3431
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3432
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3433
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3434
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3435
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3436
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3437
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3438
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3439
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3440
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3441
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3442
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3443
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3444
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3445
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3446
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3447
    }/*function_usint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3448
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3449
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3450
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3451
 *USINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3452
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3453
    case function_usint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3454
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3455
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3456
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3457
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3458
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3459
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3460
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3461
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3462
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3463
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3464
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3465
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3466
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3467
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3468
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3469
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3470
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3471
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3472
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3473
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3474
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3475
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3476
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3477
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3478
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3479
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3480
    }/*function_usint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3481
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3482
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3483
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3484
 *USINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3485
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3486
    case function_usint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3487
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3488
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3489
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3490
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3491
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3492
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3493
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3494
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3495
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3496
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3497
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3498
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3499
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3500
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3501
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3502
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3503
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3504
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3505
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3506
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3507
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3508
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3509
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3510
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3511
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3512
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3513
    }/*function_usint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3514
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3515
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3516
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3517
 *USINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3518
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3519
    case function_usint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3520
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3521
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3522
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3523
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3524
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3525
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3526
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3527
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3528
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3529
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3530
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3531
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3532
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3533
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3534
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3535
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3536
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3537
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3538
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3539
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3540
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3541
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3542
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3543
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3544
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3545
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3546
    }/*function_usint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3547
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3548
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3549
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3550
 *USINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3551
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3552
    case function_usint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3553
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3554
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3555
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3556
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3557
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3558
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3559
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3560
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3561
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3562
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3563
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3564
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3565
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3566
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3567
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3568
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3569
                s4o.print(")__uint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3570
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3571
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3572
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3573
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3574
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3575
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3576
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3577
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3578
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3579
    }/*function_usint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3580
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3581
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3582
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3583
 *USINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3584
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3585
    case function_usint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3586
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3587
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3588
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3589
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3590
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3591
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3592
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3593
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3594
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3595
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3596
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3597
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3598
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3599
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3600
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3601
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3602
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3603
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3604
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3605
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3606
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3607
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3608
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3609
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3610
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3611
    }/*function_usint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3612
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3613
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3614
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3615
 *USINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3616
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3617
    case function_usint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3618
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3619
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3620
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3621
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3622
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3623
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3624
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3625
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3626
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3627
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3628
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3629
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3630
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3631
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3632
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3633
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3634
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3635
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3636
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3637
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3638
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3639
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3640
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3641
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3642
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3643
    }/*function_usint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3644
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3645
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3646
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3647
 *USINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3648
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3649
    case function_usint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3650
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3651
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3652
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3653
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3654
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3655
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3656
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3657
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3658
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3659
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3660
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3661
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3662
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3663
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3664
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3665
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3666
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3667
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3668
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3669
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3670
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3671
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3672
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3673
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3674
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3675
    }/*function_usint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3676
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3677
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3678
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3679
 *USINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3680
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3681
    case function_usint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3682
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3683
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3684
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3685
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3686
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3687
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3688
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3689
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3690
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3691
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3692
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3693
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3694
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3695
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3696
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3697
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3698
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3699
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3700
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3701
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3702
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3703
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3704
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3705
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3706
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3707
    }/*function_usint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3708
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3709
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3710
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3711
 *UINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3712
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3713
    case function_uint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3714
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3715
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3716
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3717
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3718
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3719
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3720
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3721
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3722
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3723
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3724
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3725
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3726
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3727
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3728
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3729
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3730
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3731
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3732
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3733
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3734
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3735
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3736
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3737
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3738
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3739
    }/*function_uint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3740
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3741
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3742
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3743
 *UINT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3744
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3745
    case function_uint_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3746
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3747
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3748
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3749
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3750
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3751
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3752
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3753
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3754
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3755
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3756
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3757
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3758
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3759
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3760
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3761
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3762
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3763
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3764
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3765
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3766
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3767
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3768
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3769
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3770
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3771
    }/*function_uint_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3772
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3773
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3774
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3775
 *UINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3776
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3777
    case function_uint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3778
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3779
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3780
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3781
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3782
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3783
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3784
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3785
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3786
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3787
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3788
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3789
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3790
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3791
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3792
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3793
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3794
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3795
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3796
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3797
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3798
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3799
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3800
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3801
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3802
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3803
    }/*function_uint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3804
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3805
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3806
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3807
 *UINT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3808
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3809
    case function_uint_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3810
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3811
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3812
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3813
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3814
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3815
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3816
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3817
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3818
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3819
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3820
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3821
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3822
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3823
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3824
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3825
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3826
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3827
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3828
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3829
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3830
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3831
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3832
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3833
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3834
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3835
    }/*function_uint_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3836
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3837
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3838
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3839
 *UINT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3840
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3841
    case function_uint_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3842
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3843
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3844
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3845
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3846
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3847
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3848
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3849
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3850
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3851
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3852
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3853
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3854
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3855
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3856
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3857
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3858
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3859
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3860
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3861
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3862
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3863
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3864
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3865
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3866
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3867
    }/*function_uint_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3868
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3869
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3870
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3871
 *UINT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3872
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3873
    case function_uint_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3874
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3875
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3876
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3877
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3878
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3879
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3880
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3881
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3882
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3883
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3884
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3885
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3886
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3887
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3888
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3889
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3890
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3891
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3892
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3893
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3894
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3895
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3896
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3897
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3898
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3899
    }/*function_uint_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3900
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3901
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3902
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3903
 *UINT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3904
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3905
    case function_uint_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3906
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3907
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3908
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3909
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3910
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3911
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3912
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3913
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3914
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3915
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3916
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3917
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3918
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3919
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3920
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3921
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3922
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3923
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3924
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3925
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3926
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3927
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3928
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3929
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3930
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3931
    }/*function_uint_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3932
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3933
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3934
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3935
 *UINT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3936
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3937
    case function_uint_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3938
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3939
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3940
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3941
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3942
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3943
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3944
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3945
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3946
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3947
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3948
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3949
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3950
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3951
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3952
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3953
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3954
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3955
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3956
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3957
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3958
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3959
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3960
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3961
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3962
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3963
    }/*function_uint_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3964
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3965
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3966
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3967
 *UINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3968
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3969
    case function_uint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3970
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3971
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3972
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3973
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3974
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3975
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3976
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3977
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3978
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3979
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3980
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3981
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3982
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3983
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3984
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3985
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3986
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3987
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3988
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3989
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3990
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3991
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3992
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3993
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3994
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3995
    }/*function_uint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3996
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3997
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3998
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  3999
 *UINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4000
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4001
    case function_uint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4002
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4003
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4004
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4005
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4006
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4007
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4008
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4009
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4010
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4011
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4012
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4013
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4014
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4015
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4016
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4017
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4018
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4019
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4020
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4021
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4022
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4023
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4024
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4025
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4026
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4027
    }/*function_uint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4028
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4029
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4030
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4031
 *UINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4032
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4033
    case function_uint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4034
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4035
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4036
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4037
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4038
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4039
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4040
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4041
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4042
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4043
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4044
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4045
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4046
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4047
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4048
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4049
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4050
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4051
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4052
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4053
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4054
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4055
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4056
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4057
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4058
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4059
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4060
    }/*function_uint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4061
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4062
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4063
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4064
 *UINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4065
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4066
    case function_uint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4067
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4068
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4069
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4070
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4071
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4072
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4073
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4074
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4075
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4076
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4077
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4078
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4079
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4080
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4081
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4082
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4083
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4084
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4085
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4086
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4087
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4088
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4089
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4090
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4091
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4092
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4093
    }/*function_uint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4094
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4095
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4096
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4097
 *UINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4098
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4099
    case function_uint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4100
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4101
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4102
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4103
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4104
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4105
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4106
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4107
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4108
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4109
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4110
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4111
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4112
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4113
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4114
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4115
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4116
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4117
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4118
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4119
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4120
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4121
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4122
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4123
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4124
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4125
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4126
    }/*function_uint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4127
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4128
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4129
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4130
 *UINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4131
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4132
    case function_uint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4133
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4134
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4135
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4136
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4137
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4138
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4139
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4140
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4141
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4142
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4143
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4144
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4145
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4146
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4147
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4148
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4149
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4150
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4151
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4152
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4153
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4154
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4155
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4156
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4157
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4158
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4159
    }/*function_uint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4160
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4161
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4162
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4163
 *UINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4164
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4165
    case function_uint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4166
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4167
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4168
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4169
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4170
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4171
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4172
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4173
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4174
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4175
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4176
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4177
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4178
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4179
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4180
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4181
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4182
                s4o.print(")__uint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4183
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4184
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4185
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4186
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4187
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4188
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4189
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4190
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4191
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4192
    }/*function_uint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4193
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4194
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4195
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4196
 *UINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4197
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4198
    case function_uint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4199
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4200
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4201
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4202
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4203
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4204
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4205
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4206
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4207
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4208
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4209
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4210
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4211
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4212
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4213
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4214
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4215
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4216
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4217
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4218
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4219
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4220
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4221
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4222
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4223
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4224
    }/*function_uint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4225
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4226
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4227
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4228
 *UINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4229
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4230
    case function_uint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4231
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4232
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4233
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4234
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4235
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4236
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4237
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4238
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4239
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4240
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4241
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4242
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4243
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4244
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4245
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4246
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4247
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4248
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4249
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4250
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4251
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4252
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4253
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4254
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4255
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4256
    }/*function_uint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4257
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4258
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4259
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4260
 *UINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4261
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4262
    case function_uint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4263
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4264
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4265
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4266
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4267
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4268
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4269
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4270
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4271
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4272
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4273
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4274
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4275
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4276
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4277
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4278
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4279
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4280
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4281
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4282
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4283
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4284
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4285
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4286
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4287
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4288
    }/*function_uint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4289
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4290
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4291
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4292
 *UINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4293
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4294
    case function_uint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4295
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4296
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4297
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4298
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4299
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4300
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4301
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4302
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4303
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4304
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4305
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4306
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4307
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4308
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4309
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4310
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4311
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4312
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4313
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4314
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4315
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4316
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4317
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4318
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4319
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4320
    }/*function_uint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4321
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4322
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4323
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4324
 *UDINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4325
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4326
    case function_udint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4327
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4328
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4329
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4330
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4331
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4332
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4333
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4334
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4335
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4336
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4337
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4338
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4339
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4340
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4341
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4342
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4343
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4344
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4345
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4346
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4347
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4348
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4349
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4350
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4351
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4352
    }/*function_udint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4353
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4354
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4355
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4356
 *UDINT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4357
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4358
    case function_udint_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4359
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4360
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4361
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4362
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4363
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4364
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4365
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4366
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4367
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4368
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4369
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4370
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4371
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4372
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4373
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4374
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4375
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4376
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4377
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4378
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4379
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4380
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4381
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4382
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4383
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4384
    }/*function_udint_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4385
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4386
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4387
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4388
 *UDINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4389
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4390
    case function_udint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4391
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4392
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4393
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4394
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4395
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4396
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4397
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4398
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4399
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4400
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4401
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4402
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4403
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4404
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4405
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4406
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4407
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4408
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4409
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4410
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4411
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4412
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4413
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4414
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4415
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4416
    }/*function_udint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4417
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4418
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4419
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4420
 *UDINT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4421
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4422
    case function_udint_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4423
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4424
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4425
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4426
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4427
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4428
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4429
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4430
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4431
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4432
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4433
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4434
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4435
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4436
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4437
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4438
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4439
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4440
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4441
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4442
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4443
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4444
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4445
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4446
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4447
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4448
    }/*function_udint_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4449
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4450
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4451
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4452
 *UDINT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4453
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4454
    case function_udint_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4455
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4456
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4457
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4458
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4459
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4460
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4461
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4462
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4463
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4464
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4465
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4466
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4467
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4468
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4469
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4470
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4471
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4472
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4473
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4474
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4475
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4476
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4477
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4478
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4479
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4480
    }/*function_udint_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4481
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4482
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4483
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4484
 *UDINT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4485
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4486
    case function_udint_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4487
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4488
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4489
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4490
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4491
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4492
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4493
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4494
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4495
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4496
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4497
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4498
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4499
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4500
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4501
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4502
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4503
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4504
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4505
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4506
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4507
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4508
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4509
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4510
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4511
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4512
    }/*function_udint_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4513
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4514
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4515
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4516
 *UDINT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4517
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4518
    case function_udint_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4519
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4520
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4521
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4522
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4523
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4524
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4525
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4526
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4527
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4528
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4529
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4530
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4531
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4532
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4533
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4534
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4535
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4536
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4537
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4538
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4539
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4540
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4541
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4542
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4543
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4544
    }/*function_udint_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4545
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4546
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4547
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4548
 *UDINT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4549
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4550
    case function_udint_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4551
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4552
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4553
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4554
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4555
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4556
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4557
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4558
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4559
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4560
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4561
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4562
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4563
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4564
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4565
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4566
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4567
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4568
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4569
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4570
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4571
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4572
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4573
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4574
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4575
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4576
    }/*function_udint_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4577
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4578
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4579
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4580
 *UDINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4581
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4582
    case function_udint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4583
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4584
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4585
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4586
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4587
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4588
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4589
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4590
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4591
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4592
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4593
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4594
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4595
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4596
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4597
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4598
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4599
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4600
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4601
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4602
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4603
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4604
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4605
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4606
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4607
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4608
    }/*function_udint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4609
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4610
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4611
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4612
 *UDINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4613
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4614
    case function_udint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4615
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4616
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4617
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4618
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4619
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4620
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4621
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4622
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4623
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4624
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4625
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4626
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4627
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4628
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4629
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4630
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4631
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4632
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4633
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4634
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4635
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4636
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4637
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4638
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4639
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4640
    }/*function_udint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4641
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4642
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4643
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4644
 *UDINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4645
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4646
    case function_udint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4647
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4648
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4649
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4650
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4651
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4652
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4653
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4654
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4655
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4656
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4657
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4658
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4659
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4660
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4661
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4662
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4663
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4664
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4665
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4666
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4667
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4668
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4669
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4670
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4671
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4672
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4673
    }/*function_udint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4674
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4675
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4676
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4677
 *UDINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4678
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4679
    case function_udint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4680
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4681
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4682
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4683
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4684
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4685
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4686
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4687
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4688
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4689
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4690
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4691
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4692
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4693
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4694
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4695
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4696
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4697
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4698
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4699
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4700
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4701
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4702
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4703
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4704
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4705
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4706
    }/*function_udint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4707
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4708
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4709
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4710
 *UDINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4711
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4712
    case function_udint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4713
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4714
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4715
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4716
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4717
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4718
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4719
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4720
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4721
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4722
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4723
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4724
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4725
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4726
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4727
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4728
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4729
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4730
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4731
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4732
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4733
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4734
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4735
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4736
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4737
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4738
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4739
    }/*function_udint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4740
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4741
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4742
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4743
 *UDINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4744
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4745
    case function_udint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4746
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4747
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4748
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4749
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4750
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4751
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4752
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4753
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4754
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4755
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4756
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4757
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4758
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4759
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4760
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4761
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4762
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4763
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4764
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4765
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4766
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4767
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4768
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4769
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4770
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4771
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4772
    }/*function_udint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4773
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4774
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4775
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4776
 *UDINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4777
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4778
    case function_udint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4779
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4780
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4781
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4782
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4783
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4784
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4785
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4786
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4787
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4788
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4789
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4790
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4791
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4792
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4793
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4794
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4795
                s4o.print(")__uint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4796
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4797
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4798
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4799
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4800
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4801
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4802
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4803
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4804
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4805
    }/*function_udint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4806
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4807
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4808
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4809
 *UDINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4810
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4811
    case function_udint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4812
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4813
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4814
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4815
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4816
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4817
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4818
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4819
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4820
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4821
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4822
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4823
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4824
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4825
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4826
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4827
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4828
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4829
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4830
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4831
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4832
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4833
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4834
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4835
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4836
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4837
    }/*function_udint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4838
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4839
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4840
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4841
 *UDINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4842
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4843
    case function_udint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4844
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4845
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4846
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4847
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4848
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4849
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4850
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4851
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4852
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4853
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4854
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4855
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4856
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4857
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4858
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4859
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4860
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4861
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4862
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4863
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4864
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4865
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4866
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4867
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4868
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4869
    }/*function_udint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4870
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4871
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4872
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4873
 *UDINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4874
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4875
    case function_udint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4876
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4877
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4878
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4879
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4880
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4881
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4882
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4883
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4884
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4885
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4886
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4887
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4888
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4889
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4890
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4891
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4892
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4893
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4894
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4895
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4896
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4897
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4898
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4899
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4900
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4901
    }/*function_udint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4902
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4903
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4904
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4905
 *UDINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4906
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4907
    case function_udint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4908
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4909
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4910
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4911
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4912
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4913
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4914
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4915
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4916
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4917
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4918
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4919
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4920
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4921
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4922
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4923
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4924
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4925
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4926
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4927
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4928
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4929
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4930
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4931
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4932
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4933
    }/*function_udint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4934
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4935
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4936
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4937
 *ULINT_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4938
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4939
    case function_ulint_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4940
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4941
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4942
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4943
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4944
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4945
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4946
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4947
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4948
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4949
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4950
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4951
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4952
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4953
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4954
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4955
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4956
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4957
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4958
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4959
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4960
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4961
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4962
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4963
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4964
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4965
    }/*function_ulint_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4966
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4967
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4968
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4969
 *ULINT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4970
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4971
    case function_ulint_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4972
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4973
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4974
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4975
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4976
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4977
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4978
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4979
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4980
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4981
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4982
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4983
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4984
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4985
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4986
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4987
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4988
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4989
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4990
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4991
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4992
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4993
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4994
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4995
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4996
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4997
    }/*function_ulint_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4998
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  4999
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5000
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5001
 *ULINT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5002
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5003
    case function_ulint_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5004
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5005
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5006
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5007
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5008
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5009
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5010
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5011
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5012
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5013
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5014
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5015
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5016
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5017
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5018
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5019
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5020
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5021
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5022
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5023
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5024
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5025
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5026
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5027
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5028
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5029
    }/*function_ulint_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5030
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5031
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5032
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5033
 *ULINT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5034
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5035
    case function_ulint_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5036
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5037
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5038
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5039
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5040
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5041
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5042
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5043
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5044
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5045
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5046
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5047
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5048
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5049
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5050
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5051
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5052
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5053
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5054
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5055
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5056
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5057
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5058
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5059
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5060
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5061
    }/*function_ulint_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5062
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5063
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5064
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5065
 *ULINT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5066
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5067
    case function_ulint_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5068
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5069
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5070
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5071
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5072
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5073
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5074
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5075
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5076
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5077
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5078
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5079
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5080
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5081
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5082
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5083
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5084
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5085
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5086
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5087
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5088
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5089
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5090
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5091
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5092
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5093
    }/*function_ulint_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5094
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5095
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5096
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5097
 *ULINT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5098
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5099
    case function_ulint_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5100
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5101
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5102
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5103
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5104
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5105
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5106
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5107
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5108
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5109
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5110
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5111
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5112
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5113
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5114
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5115
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5116
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5117
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5118
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5119
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5120
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5121
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5122
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5123
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5124
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5125
    }/*function_ulint_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5126
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5127
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5128
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5129
 *ULINT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5130
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5131
    case function_ulint_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5132
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5133
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5134
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5135
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5136
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5137
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5138
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5139
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5140
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5141
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5142
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5143
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5144
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5145
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5146
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5147
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5148
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5149
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5150
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5151
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5152
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5153
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5154
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5155
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5156
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5157
    }/*function_ulint_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5158
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5159
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5160
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5161
 *ULINT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5162
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5163
    case function_ulint_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5164
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5165
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5166
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5167
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5168
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5169
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5170
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5171
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5172
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5173
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5174
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5175
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5176
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5177
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5178
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5179
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5180
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5181
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5182
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5183
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5184
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5185
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5186
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5187
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5188
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5189
    }/*function_ulint_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5190
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5191
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5192
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5193
 *ULINT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5194
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5195
    case function_ulint_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5196
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5197
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5198
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5199
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5200
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5201
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5202
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5203
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5204
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5205
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5206
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5207
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5208
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5209
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5210
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5211
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5212
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5213
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5214
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5215
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5216
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5217
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5218
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5219
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5220
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5221
    }/*function_ulint_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5222
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5223
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5224
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5225
 *ULINT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5226
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5227
    case function_ulint_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5228
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5229
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5230
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5231
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5232
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5233
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5234
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5235
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5236
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5237
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5238
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5239
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5240
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5241
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5242
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5243
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5244
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5245
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5246
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5247
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5248
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5249
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5250
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5251
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5252
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5253
    }/*function_ulint_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5254
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5255
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5256
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5257
 *ULINT_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5258
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5259
    case function_ulint_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5260
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5261
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5262
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5263
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5264
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5265
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5266
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5267
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5268
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5269
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5270
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5271
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5272
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5273
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5274
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5275
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5276
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5277
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5278
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5279
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5280
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5281
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5282
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5283
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5284
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5285
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5286
    }/*function_ulint_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5287
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5288
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5289
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5290
 *ULINT_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5291
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5292
    case function_ulint_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5293
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5294
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5295
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5296
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5297
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5298
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5299
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5300
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5301
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5302
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5303
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5304
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5305
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5306
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5307
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5308
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5309
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5310
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5311
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5312
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5313
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5314
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5315
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5316
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5317
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5318
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5319
    }/*function_ulint_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5320
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5321
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5322
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5323
 *ULINT_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5324
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5325
    case function_ulint_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5326
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5327
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5328
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5329
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5330
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5331
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5333
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5334
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5335
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5336
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5337
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5338
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5339
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5340
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5341
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5342
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5343
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5344
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5345
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5346
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5347
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5348
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5349
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5350
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5351
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5352
    }/*function_ulint_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5353
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5354
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5355
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5356
 *ULINT_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5357
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5358
    case function_ulint_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5359
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5360
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5361
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5362
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5363
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5364
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5365
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5366
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5367
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5368
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5369
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5370
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5371
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5372
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5373
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5374
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5375
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5376
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5377
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5378
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5379
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5380
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5381
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5382
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5383
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5384
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5385
    }/*function_ulint_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5386
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5387
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5388
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5389
 *ULINT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5390
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5391
    case function_ulint_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5392
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5393
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5394
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5395
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5396
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5397
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5398
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5399
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5400
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5401
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5402
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5403
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5404
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5405
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5406
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5407
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5408
                s4o.print(")__uint_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5409
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5410
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5411
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5412
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5413
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5414
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5415
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5416
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5417
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5418
    }/*function_ulint_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5419
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5420
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5421
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5422
 *ULINT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5423
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5424
    case function_ulint_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5425
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5426
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5427
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5428
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5429
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5430
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5431
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5432
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5433
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5434
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5435
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5436
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5437
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5438
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5439
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5440
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5441
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5442
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5443
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5444
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5445
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5446
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5447
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5448
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5449
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5450
    }/*function_ulint_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5451
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5452
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5453
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5454
 *ULINT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5455
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5456
    case function_ulint_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5457
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5458
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5459
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5460
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5461
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5462
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5463
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5464
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5465
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5466
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5467
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5468
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5469
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5470
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5471
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5472
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5473
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5474
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5475
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5476
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5477
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5478
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5479
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5480
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5481
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5482
    }/*function_ulint_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5483
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5484
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5485
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5486
 *ULINT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5487
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5488
    case function_ulint_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5489
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5490
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5491
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5492
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5493
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5494
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5495
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5496
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5497
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5498
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5499
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5500
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5501
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5502
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5503
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5504
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5505
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5506
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5507
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5508
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5509
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5510
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5511
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5512
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5513
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5514
    }/*function_ulint_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5515
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5516
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5517
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5518
 *ULINT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5519
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5520
    case function_ulint_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5521
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5522
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5523
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5524
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5525
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5526
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5527
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5528
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5529
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5530
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5531
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5532
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5533
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5534
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5535
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5536
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5537
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5538
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5539
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5540
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5541
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5542
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5543
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5544
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5545
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5546
    }/*function_ulint_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5547
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5548
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5549
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5550
 *REAL_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5551
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5552
    case function_real_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5553
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5554
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5555
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5556
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5557
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5558
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5559
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5560
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5561
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5562
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5563
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5564
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5565
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5566
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5567
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5568
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5569
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5570
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5571
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5572
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5573
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5574
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5575
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5576
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5577
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5578
    }/*function_real_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5579
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5580
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5581
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5582
 *REAL_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5583
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5584
    case function_real_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5585
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5586
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5587
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5588
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5589
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5590
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5591
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5592
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5593
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5594
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5595
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5596
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5597
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5598
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5599
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5600
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5601
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5602
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5603
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5604
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5605
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5606
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5607
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5608
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5609
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5610
    }/*function_real_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5611
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5612
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5613
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5614
 *REAL_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5615
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5616
    case function_real_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5617
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5618
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5619
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5620
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5621
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5622
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5623
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5624
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5625
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5626
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5627
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5628
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5629
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5630
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5631
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5632
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5633
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5634
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5635
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5636
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5637
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5638
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5639
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5640
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5641
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5642
    }/*function_real_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5643
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5644
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5645
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5646
 *REAL_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5647
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5648
    case function_real_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5649
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5650
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5651
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5652
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5653
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5654
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5655
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5656
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5657
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5658
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5659
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5660
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5661
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5662
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5663
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5664
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5665
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5666
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5667
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5668
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5669
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5670
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5671
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5672
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5673
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5674
    }/*function_real_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5675
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5676
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5677
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5678
 *REAL_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5679
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5680
    case function_real_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5681
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5682
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5683
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5684
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5685
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5686
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5687
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5688
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5689
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5690
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5691
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5692
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5693
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5694
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5695
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5696
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5697
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5698
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5699
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5700
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5701
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5702
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5703
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5704
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5705
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5706
    }/*function_real_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5707
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5708
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5709
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5710
 *REAL_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5711
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5712
    case function_real_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5713
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5714
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5715
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5716
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5717
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5718
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5719
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5720
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5721
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5722
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5723
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5724
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5725
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5726
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5727
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5728
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5729
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5730
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5731
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5732
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5733
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5734
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5735
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5736
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5737
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5738
    }/*function_real_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5739
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5740
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5741
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5742
 *REAL_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5743
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5744
    case function_real_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5745
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5746
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5747
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5748
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5749
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5750
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5751
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5752
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5753
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5754
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5755
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5756
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5757
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5758
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5759
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5760
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5761
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5762
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5763
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5764
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5765
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5766
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5767
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5768
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5769
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5770
    }/*function_real_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5771
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5772
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5773
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5774
 *REAL_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5775
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5776
    case function_real_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5777
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5778
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5779
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5780
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5781
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5782
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5783
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5784
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5785
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5786
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5787
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5788
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5789
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5790
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5791
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5792
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5793
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5794
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5795
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5796
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5797
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5798
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5799
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5800
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5801
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5802
    }/*function_real_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5803
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5804
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5805
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5806
 *REAL_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5807
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5808
    case function_real_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5809
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5810
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5811
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5812
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5813
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5814
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5815
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5816
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5817
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5818
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5819
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5820
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5821
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5822
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5823
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5824
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5825
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5826
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5827
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5828
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5829
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5830
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5831
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5832
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5833
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5834
    }/*function_real_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5835
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5836
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5837
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5838
 *REAL_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5839
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5840
    case function_real_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5841
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5842
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5843
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5844
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5845
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5846
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5847
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5848
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5849
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5850
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5851
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5852
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5853
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5854
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5855
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5856
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5857
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5858
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5859
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5860
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5861
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5862
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5863
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5864
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5865
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5866
    }/*function_real_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5867
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5868
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5869
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5870
 *REAL_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5871
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5872
    case function_real_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5873
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5874
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5875
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5876
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5877
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5878
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5879
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5880
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5881
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5882
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5883
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5884
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5885
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5886
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5887
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5888
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5889
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5890
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5891
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5892
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5893
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5894
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5895
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5896
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5897
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5898
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5899
    }/*function_real_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5900
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5901
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5902
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5903
 *REAL_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5904
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5905
    case function_real_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5906
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5907
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5908
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5909
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5910
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5911
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5912
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5913
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5914
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5915
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5916
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5917
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5918
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5919
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5920
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5921
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5922
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5923
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5924
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5925
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5926
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5927
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5928
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5929
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5930
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5931
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5932
    }/*function_real_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5933
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5934
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5935
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5936
 *REAL_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5937
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5938
    case function_real_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5939
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5940
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5941
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5942
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5943
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5944
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5945
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5946
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5947
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5948
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5949
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5950
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5951
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5952
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5953
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5954
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5955
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5956
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5957
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5958
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5959
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5960
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5961
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5962
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5963
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5964
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5965
    }/*function_real_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5966
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5967
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5968
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5969
 *REAL_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5970
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5971
    case function_real_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5972
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5973
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5974
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5975
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5976
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5977
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5978
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5979
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5980
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5981
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5982
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5983
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5984
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5985
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5986
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5987
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5988
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5989
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5990
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5991
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5992
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5993
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5994
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5995
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5996
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5997
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5998
    }/*function_real_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  5999
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6000
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6001
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6002
 *REAL_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6003
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6004
    case function_real_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6005
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6006
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6007
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6008
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6009
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6010
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6011
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6012
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6013
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6014
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6015
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6016
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6017
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6018
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6019
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6020
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6021
                s4o.print(")__real_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6022
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6023
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6024
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6025
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6026
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6027
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6028
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6029
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6030
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6031
    }/*function_real_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6032
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6033
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6034
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6035
 *REAL_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6036
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6037
    case function_real_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6038
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6039
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6040
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6041
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6042
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6043
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6044
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6045
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6046
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6047
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6048
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6049
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6050
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6051
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6052
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6053
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6054
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6055
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6056
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6057
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6058
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6059
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6060
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6061
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6062
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6063
    }/*function_real_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6064
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6065
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6066
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6067
 *REAL_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6068
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6069
    case function_real_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6070
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6071
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6072
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6073
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6074
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6075
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6076
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6077
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6078
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6079
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6080
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6081
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6082
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6083
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6084
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6085
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6086
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6087
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6088
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6089
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6090
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6091
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6092
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6093
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6094
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6095
    }/*function_real_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6096
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6097
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6098
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6099
 *REAL_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6100
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6101
    case function_real_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6102
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6103
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6104
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6105
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6106
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6107
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6108
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6109
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6110
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6111
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6112
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6113
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6114
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6115
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6116
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6117
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6118
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6119
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6120
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6121
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6122
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6123
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6124
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6125
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6126
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6127
    }/*function_real_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6128
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6129
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6130
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6131
 *REAL_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6132
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6133
    case function_real_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6134
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6135
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6136
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6137
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6138
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6139
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6140
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6141
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6142
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6143
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6144
            if(search_expression_type->is_same_type(&search_constant_type_c::real_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6145
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6146
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6147
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6148
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6149
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6150
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6151
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6152
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6153
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6154
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6155
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6156
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6157
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6158
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6159
    }/*function_real_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6160
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6161
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6162
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6163
 *LREAL_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6164
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6165
    case function_lreal_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6166
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6167
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6168
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6169
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6170
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6171
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6172
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6173
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6174
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6175
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6176
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6177
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6178
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6179
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6180
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6181
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6182
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6183
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6184
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6185
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6186
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6187
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6188
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6189
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6190
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6191
    }/*function_lreal_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6192
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6193
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6194
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6195
 *LREAL_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6196
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6197
    case function_lreal_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6198
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6199
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6200
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6201
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6202
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6203
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6204
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6205
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6206
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6207
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6208
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6209
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6210
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6211
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6212
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6213
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6214
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6215
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6216
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6217
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6218
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6219
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6220
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6221
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6222
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6223
    }/*function_lreal_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6224
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6225
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6226
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6227
 *LREAL_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6228
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6229
    case function_lreal_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6230
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6231
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6232
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6233
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6234
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6235
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6236
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6237
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6238
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6239
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6240
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6241
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6242
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6243
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6244
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6245
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6246
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6247
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6248
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6249
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6250
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6251
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6252
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6253
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6254
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6255
    }/*function_lreal_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6256
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6257
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6258
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6259
 *LREAL_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6260
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6261
    case function_lreal_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6262
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6263
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6264
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6265
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6266
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6267
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6268
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6269
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6270
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6271
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6272
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6273
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6274
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6275
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6276
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6277
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6278
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6279
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6280
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6281
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6282
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6283
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6284
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6285
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6286
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6287
    }/*function_lreal_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6288
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6289
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6290
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6291
 *LREAL_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6292
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6293
    case function_lreal_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6294
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6295
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6296
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6297
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6298
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6299
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6300
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6301
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6302
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6303
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6304
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6305
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6306
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6307
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6308
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6309
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6310
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6311
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6312
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6313
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6314
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6315
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6316
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6317
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6318
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6319
    }/*function_lreal_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6320
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6321
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6322
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6323
 *LREAL_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6324
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6325
    case function_lreal_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6326
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6327
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6328
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6329
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6330
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6331
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6333
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6334
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6335
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6336
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6337
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6338
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6339
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6340
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6341
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6342
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6343
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6344
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6345
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6346
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6347
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6348
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6349
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6350
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6351
    }/*function_lreal_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6352
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6353
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6354
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6355
 *LREAL_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6356
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6357
    case function_lreal_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6358
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6359
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6360
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6361
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6362
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6363
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6364
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6365
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6366
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6367
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6368
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6369
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6370
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6371
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6372
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6373
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6374
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6375
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6376
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6377
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6378
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6379
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6380
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6381
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6382
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6383
    }/*function_lreal_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6384
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6385
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6386
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6387
 *LREAL_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6388
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6389
    case function_lreal_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6390
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6391
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6392
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6393
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6394
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6395
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6396
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6397
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6398
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6399
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6400
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6401
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6402
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6403
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6404
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6405
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6406
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6407
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6408
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6409
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6410
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6411
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6412
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6413
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6414
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6415
    }/*function_lreal_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6416
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6417
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6418
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6419
 *LREAL_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6420
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6421
    case function_lreal_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6422
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6423
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6424
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6425
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6426
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6427
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6428
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6429
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6430
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6431
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6432
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6433
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6434
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6435
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6436
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6437
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6438
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6439
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6440
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6441
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6442
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6443
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6444
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6445
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6446
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6447
    }/*function_lreal_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6448
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6449
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6450
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6451
 *LREAL_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6452
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6453
    case function_lreal_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6454
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6455
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6456
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6457
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6458
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6459
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6460
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6461
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6462
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6463
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6464
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6465
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6466
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6467
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6468
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6469
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6470
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6471
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6472
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6473
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6474
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6475
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6476
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6477
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6478
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6479
    }/*function_lreal_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6480
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6481
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6482
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6483
 *LREAL_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6484
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6485
    case function_lreal_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6486
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6487
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6488
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6489
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6490
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6491
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6492
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6493
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6494
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6495
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6496
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6497
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6498
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6499
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6500
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6501
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6502
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6503
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6504
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6505
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6506
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6507
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6508
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6509
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6510
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6511
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6512
    }/*function_lreal_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6513
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6514
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6515
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6516
 *LREAL_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6517
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6518
    case function_lreal_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6519
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6520
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6521
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6522
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6523
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6524
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6525
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6526
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6527
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6528
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6529
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6530
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6531
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6532
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6533
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6534
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6535
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6536
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6537
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6538
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6539
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6540
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6541
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6542
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6543
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6544
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6545
    }/*function_lreal_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6546
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6547
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6548
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6549
 *LREAL_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6550
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6551
    case function_lreal_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6552
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6553
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6554
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6555
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6556
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6557
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6558
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6559
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6560
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6561
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6562
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6563
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6564
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6565
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6566
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6567
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6568
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6569
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6570
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6571
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6572
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6573
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6574
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6575
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6576
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6577
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6578
    }/*function_lreal_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6579
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6580
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6581
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6582
 *LREAL_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6583
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6584
    case function_lreal_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6585
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6586
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6587
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6588
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6589
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6590
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6591
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6592
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6593
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6594
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6595
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6596
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6597
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6598
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6599
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6600
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6601
                s4o.print(")__real_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6602
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6603
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6604
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6605
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6606
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6607
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6608
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6609
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6610
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6611
    }/*function_lreal_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6612
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6613
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6614
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6615
 *LREAL_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6616
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6617
    case function_lreal_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6618
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6619
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6620
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6621
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6622
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6623
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6624
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6625
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6626
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6627
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6628
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6629
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6630
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6631
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6632
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6633
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6634
                s4o.print(")__real_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6635
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6636
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6637
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6638
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6639
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6640
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6641
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6642
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6643
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6644
    }/*function_lreal_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6645
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6646
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6647
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6648
 *LREAL_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6649
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6650
    case function_lreal_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6651
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6652
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6653
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6654
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6655
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6656
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6657
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6658
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6659
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6660
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6661
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6662
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6663
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6664
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6665
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6666
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6667
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6668
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6669
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6670
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6671
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6672
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6673
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6674
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6675
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6676
    }/*function_lreal_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6677
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6678
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6679
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6680
 *LREAL_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6681
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6682
    case function_lreal_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6683
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6684
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6685
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6686
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6687
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6688
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6689
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6690
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6691
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6692
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6693
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6694
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6695
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6696
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6697
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6698
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6699
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6700
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6701
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6702
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6703
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6704
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6705
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6706
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6707
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6708
    }/*function_lreal_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6709
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6710
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6711
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6712
 *LREAL_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6713
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6714
    case function_lreal_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6715
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6716
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6717
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6718
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6719
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6720
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6721
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6722
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6723
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6724
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6725
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6726
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6727
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6728
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6729
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6730
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6731
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6732
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6733
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6734
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6735
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6736
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6737
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6738
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6739
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6740
    }/*function_lreal_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6741
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6742
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6743
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6744
 *LREAL_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6745
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6746
    case function_lreal_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6747
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6748
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6749
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6750
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6751
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6752
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6753
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6754
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6755
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6756
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6757
            if(search_expression_type->is_same_type(&search_constant_type_c::lreal_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6758
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6759
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6760
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6761
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6762
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6763
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6764
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6765
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6766
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6767
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6768
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6769
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6770
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6771
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6772
    }/*function_lreal_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6773
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6774
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6775
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6776
 *TIME_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6777
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6778
    case function_time_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6779
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6780
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6781
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6782
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6783
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6784
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6785
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6786
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6787
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6788
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6789
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6790
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6791
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6792
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6793
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6794
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6795
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6796
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6797
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6798
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6799
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6800
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6801
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6802
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6803
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6804
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6805
    }/*function_time_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6806
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6807
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6808
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6809
 *TIME_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6810
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6811
    case function_time_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6812
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6813
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6814
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6815
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6816
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6817
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6818
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6819
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6820
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6821
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6822
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6823
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6824
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6825
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6826
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6827
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6828
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6829
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6830
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6831
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6832
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6833
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6834
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6835
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6836
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6837
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6838
    }/*function_time_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6839
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6840
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6841
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6842
 *TIME_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6843
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6844
    case function_time_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6845
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6846
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6847
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6848
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6849
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6850
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6851
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6852
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6853
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6854
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6855
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6856
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6857
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6858
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6859
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6860
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6861
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6862
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6863
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6864
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6865
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6866
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6867
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6868
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6869
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6870
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6871
    }/*function_time_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6872
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6873
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6874
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6875
 *TIME_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6876
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6877
    case function_time_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6878
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6879
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6880
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6881
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6882
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6883
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6884
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6885
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6886
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6887
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6888
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6889
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6890
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6891
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6892
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6893
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6894
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6895
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6896
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6897
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6898
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6899
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6900
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6901
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6902
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6903
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6904
    }/*function_time_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6905
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6906
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6907
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6908
 *TIME_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6909
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6910
    case function_time_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6911
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6912
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6913
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6914
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6915
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6916
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6917
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6918
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6919
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6920
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6921
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6922
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6923
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6924
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6925
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6926
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6927
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6928
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6929
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6930
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6931
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6932
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6933
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6934
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6935
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6936
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6937
    }/*function_time_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6938
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6939
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6940
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6941
 *TIME_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6942
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6943
    case function_time_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6944
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6945
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6946
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6947
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6948
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6949
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6950
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6951
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6952
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6953
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6954
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6955
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6956
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6957
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6958
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6959
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6960
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6961
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6962
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6963
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6964
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6965
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6966
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6967
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6968
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6969
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6970
    }/*function_time_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6971
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6972
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6973
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6974
 *TIME_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6975
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6976
    case function_time_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6977
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6978
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6979
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6980
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6981
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6982
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6983
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6984
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6985
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6986
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6987
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6988
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6989
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6990
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6991
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6992
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6993
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6994
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6995
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6996
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6997
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6998
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  6999
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7000
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7001
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7002
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7003
    }/*function_time_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7004
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7005
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7006
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7007
 *TIME_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7008
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7009
    case function_time_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7010
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7011
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7012
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7013
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7014
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7015
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7016
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7017
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7018
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7019
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7020
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7021
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7022
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7023
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7024
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7025
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7026
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7027
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7028
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7029
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7030
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7031
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7032
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7033
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7034
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7035
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7036
    }/*function_time_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7037
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7038
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7039
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7040
 *TIME_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7041
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7042
    case function_time_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7043
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7044
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7045
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7046
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7047
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7048
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7049
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7050
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7051
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7052
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7053
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7054
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7055
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7056
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7057
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7058
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7059
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7060
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7061
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7062
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7063
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7064
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7065
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7066
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7067
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7068
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7069
    }/*function_time_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7070
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7071
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7072
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7073
 *TIME_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7074
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7075
    case function_time_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7076
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7077
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7078
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7079
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7080
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7081
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7082
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7083
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7084
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7085
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7086
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7087
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7088
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7089
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7090
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7091
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7092
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7093
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7094
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7095
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7096
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7097
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7098
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7099
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7100
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7101
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7102
    }/*function_time_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7103
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7104
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7105
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7106
 *TIME_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7107
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7108
    case function_time_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7109
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7110
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7111
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7112
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7113
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7114
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7115
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7116
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7117
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7118
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7119
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7120
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7121
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7122
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7123
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7124
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7125
                s4o.print(")__time_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7126
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7127
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7128
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7129
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7130
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7131
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7132
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7133
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7134
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7135
    }/*function_time_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7136
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7137
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7138
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7139
 *TIME_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7140
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7141
    case function_time_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7142
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7143
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7144
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7145
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7146
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7147
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7148
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7149
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7150
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7151
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7152
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7153
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7154
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7155
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7156
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7157
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7158
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7159
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7160
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7161
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7162
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7163
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7164
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7165
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7166
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7167
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7168
    }/*function_time_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7169
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7170
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7171
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7172
 *TIME_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7173
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7174
    case function_time_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7175
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7176
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7177
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7178
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7179
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7180
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7181
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7182
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7183
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7184
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7185
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7186
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7187
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7188
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7189
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7190
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7191
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7192
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7193
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7194
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7195
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7196
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7197
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7198
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7199
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7200
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7201
    }/*function_time_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7202
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7203
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7204
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7205
 *TIME_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7206
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7207
    case function_time_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7208
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7209
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7210
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7211
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7212
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7213
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7214
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7215
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7216
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7217
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7218
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7219
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7220
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7221
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7222
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7223
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7224
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7225
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7226
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7227
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7228
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7229
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7230
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7231
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7232
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7233
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7234
    }/*function_time_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7235
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7236
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7237
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7238
 *TIME_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7239
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7240
    case function_time_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7241
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7242
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7243
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7244
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7245
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7246
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7247
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7248
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7249
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7250
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7251
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7252
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7253
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7254
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7255
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7256
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7257
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7258
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7259
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7260
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7261
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7262
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7263
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7264
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7265
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7266
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7267
    }/*function_time_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7268
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7269
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7270
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7271
 *DATE_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7272
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7273
    case function_date_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7274
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7275
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7276
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7277
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7278
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7279
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7280
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7281
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7282
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7283
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7284
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7285
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7286
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7287
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7288
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7289
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7290
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7291
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7292
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7293
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7294
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7295
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7296
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7297
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7298
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7299
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7300
    }/*function_date_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7301
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7302
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7303
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7304
 *DATE_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7305
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7306
    case function_date_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7307
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7308
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7309
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7310
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7311
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7312
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7313
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7314
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7315
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7316
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7317
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7318
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7319
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7320
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7321
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7322
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7323
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7324
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7325
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7326
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7327
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7328
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7329
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7330
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7331
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7333
    }/*function_date_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7334
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7335
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7336
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7337
 *DATE_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7338
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7339
    case function_date_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7340
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7341
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7342
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7343
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7344
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7345
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7346
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7347
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7348
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7349
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7350
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7351
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7352
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7353
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7354
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7355
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7356
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7357
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7358
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7359
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7360
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7361
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7362
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7363
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7364
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7365
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7366
    }/*function_date_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7367
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7368
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7369
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7370
 *DATE_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7371
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7372
    case function_date_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7373
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7374
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7375
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7376
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7377
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7378
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7379
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7380
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7381
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7382
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7383
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7384
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7385
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7386
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7387
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7388
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7389
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7390
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7391
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7392
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7393
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7394
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7395
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7396
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7397
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7398
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7399
    }/*function_date_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7400
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7401
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7402
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7403
 *DATE_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7404
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7405
    case function_date_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7406
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7407
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7408
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7409
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7410
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7411
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7412
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7413
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7414
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7415
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7416
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7417
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7418
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7419
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7420
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7421
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7422
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7423
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7424
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7425
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7426
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7427
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7428
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7429
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7430
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7431
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7432
    }/*function_date_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7433
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7434
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7435
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7436
 *DATE_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7437
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7438
    case function_date_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7439
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7440
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7441
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7442
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7443
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7444
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7445
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7446
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7447
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7448
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7449
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7450
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7451
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7452
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7453
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7454
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7455
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7456
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7457
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7458
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7459
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7460
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7461
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7462
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7463
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7464
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7465
    }/*function_date_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7466
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7467
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7468
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7469
 *DATE_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7470
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7471
    case function_date_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7472
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7473
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7474
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7475
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7476
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7477
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7478
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7479
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7480
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7481
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7482
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7483
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7484
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7485
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7486
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7487
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7488
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7489
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7490
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7491
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7492
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7493
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7494
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7495
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7496
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7497
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7498
    }/*function_date_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7499
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7500
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7501
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7502
 *DATE_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7503
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7504
    case function_date_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7505
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7506
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7507
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7508
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7509
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7510
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7511
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7512
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7513
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7514
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7515
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7516
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7517
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7518
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7519
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7520
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7521
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7522
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7523
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7524
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7525
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7526
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7527
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7528
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7529
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7530
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7531
    }/*function_date_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7532
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7533
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7534
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7535
 *DATE_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7536
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7537
    case function_date_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7538
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7539
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7540
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7541
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7542
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7543
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7544
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7545
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7546
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7547
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7548
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7549
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7550
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7551
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7552
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7553
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7554
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7555
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7556
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7557
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7558
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7559
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7560
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7561
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7562
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7563
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7564
    }/*function_date_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7565
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7566
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7567
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7568
 *DATE_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7569
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7570
    case function_date_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7571
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7572
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7573
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7574
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7575
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7576
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7577
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7578
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7579
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7580
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7581
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7582
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7583
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7584
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7585
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7586
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7587
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7588
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7589
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7590
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7591
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7592
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7593
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7594
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7595
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7596
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7597
    }/*function_date_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7598
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7599
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7600
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7601
 *DATE_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7602
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7603
    case function_date_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7604
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7605
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7606
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7607
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7608
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7609
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7610
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7611
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7612
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7613
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7614
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7615
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7616
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7617
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7618
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7619
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7620
                s4o.print(")__date_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7621
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7622
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7623
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7624
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7625
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7626
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7627
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7628
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7629
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7630
    }/*function_date_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7631
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7632
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7633
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7634
 *DATE_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7635
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7636
    case function_date_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7637
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7638
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7639
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7640
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7641
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7642
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7643
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7644
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7645
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7646
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7647
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7648
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7649
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7650
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7651
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7652
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7653
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7654
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7655
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7656
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7657
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7658
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7659
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7660
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7661
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7662
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7663
    }/*function_date_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7664
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7665
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7666
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7667
 *DATE_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7668
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7669
    case function_date_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7670
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7671
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7672
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7673
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7674
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7675
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7676
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7677
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7678
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7679
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7680
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7681
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7682
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7683
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7684
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7685
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7686
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7687
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7688
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7689
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7690
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7691
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7692
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7693
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7694
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7695
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7696
    }/*function_date_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7697
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7698
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7699
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7700
 *DATE_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7701
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7702
    case function_date_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7703
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7704
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7705
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7706
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7707
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7708
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7709
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7710
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7711
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7712
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7713
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7714
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7715
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7716
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7717
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7718
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7719
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7720
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7721
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7722
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7723
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7724
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7725
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7726
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7727
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7728
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7729
    }/*function_date_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7730
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7731
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7732
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7733
 *DATE_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7734
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7735
    case function_date_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7736
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7737
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7738
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7739
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7740
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7741
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7742
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7743
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7744
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7745
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7746
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7747
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7748
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7749
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7750
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7751
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7752
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7753
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7754
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7755
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7756
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7757
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7758
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7759
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7760
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7761
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7762
    }/*function_date_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7763
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7764
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7765
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7766
 *TOD_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7767
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7768
    case function_tod_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7769
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7770
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7771
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7772
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7773
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7774
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7775
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7776
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7777
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7778
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7779
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7780
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7781
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7782
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7783
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7784
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7785
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7786
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7787
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7788
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7789
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7790
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7791
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7792
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7793
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7794
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7795
    }/*function_tod_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7796
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7797
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7798
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7799
 *TOD_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7800
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7801
    case function_tod_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7802
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7803
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7804
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7805
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7806
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7807
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7808
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7809
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7810
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7811
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7812
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7813
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7814
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7815
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7816
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7817
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7818
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7819
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7820
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7821
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7822
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7823
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7824
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7825
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7826
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7827
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7828
    }/*function_tod_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7829
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7830
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7831
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7832
 *TOD_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7833
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7834
    case function_tod_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7835
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7836
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7837
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7838
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7839
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7840
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7841
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7842
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7843
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7844
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7845
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7846
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7847
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7848
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7849
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7850
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7851
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7852
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7853
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7854
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7855
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7856
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7857
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7858
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7859
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7860
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7861
    }/*function_tod_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7862
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7863
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7864
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7865
 *TOD_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7866
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7867
    case function_tod_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7868
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7869
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7870
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7871
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7872
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7873
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7874
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7875
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7876
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7877
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7878
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7879
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7880
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7881
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7882
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7883
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7884
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7885
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7886
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7887
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7888
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7889
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7890
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7891
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7892
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7893
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7894
    }/*function_tod_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7895
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7896
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7897
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7898
 *TOD_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7899
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7900
    case function_tod_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7901
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7902
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7903
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7904
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7905
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7906
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7907
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7908
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7909
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7910
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7911
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7912
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7913
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7914
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7915
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7916
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7917
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7918
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7919
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7920
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7921
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7922
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7923
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7924
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7925
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7926
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7927
    }/*function_tod_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7928
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7929
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7930
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7931
 *TOD_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7932
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7933
    case function_tod_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7934
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7935
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7936
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7937
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7938
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7939
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7940
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7941
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7942
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7943
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7944
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7945
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7946
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7947
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7948
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7949
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7950
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7951
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7952
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7953
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7954
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7955
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7956
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7957
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7958
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7959
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7960
    }/*function_tod_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7961
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7962
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7963
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7964
 *TOD_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7965
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7966
    case function_tod_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7967
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7968
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7969
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7970
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7971
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7972
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7973
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7974
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7975
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7976
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7977
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7978
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7979
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7980
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7981
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7982
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7983
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7984
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7985
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7986
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7987
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7988
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7989
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7990
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7991
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7992
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7993
    }/*function_tod_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7994
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7995
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7996
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7997
 *TOD_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7998
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  7999
    case function_tod_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8000
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8001
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8002
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8003
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8004
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8005
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8006
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8007
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8008
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8009
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8010
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8011
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8012
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8013
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8014
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8015
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8016
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8017
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8018
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8019
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8020
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8021
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8022
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8023
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8024
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8025
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8026
    }/*function_tod_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8027
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8028
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8029
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8030
 *TOD_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8031
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8032
    case function_tod_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8033
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8034
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8035
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8036
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8037
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8038
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8039
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8040
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8041
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8042
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8043
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8044
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8045
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8046
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8047
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8048
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8049
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8050
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8051
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8052
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8053
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8054
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8055
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8056
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8057
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8058
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8059
    }/*function_tod_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8060
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8061
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8062
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8063
 *TOD_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8064
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8065
    case function_tod_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8066
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8067
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8068
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8069
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8070
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8071
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8072
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8073
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8074
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8075
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8076
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8077
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8078
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8079
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8080
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8081
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8082
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8083
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8084
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8085
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8086
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8087
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8088
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8089
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8090
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8091
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8092
    }/*function_tod_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8093
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8094
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8095
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8096
 *TOD_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8097
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8098
    case function_tod_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8099
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8100
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8101
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8102
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8103
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8104
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8105
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8106
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8107
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8108
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8109
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8110
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8111
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8112
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8113
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8114
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8115
                s4o.print(")__tod_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8116
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8117
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8118
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8119
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8120
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8121
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8122
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8123
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8124
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8125
    }/*function_tod_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8126
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8127
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8128
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8129
 *TOD_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8130
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8131
    case function_tod_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8132
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8133
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8134
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8135
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8136
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8137
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8138
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8139
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8140
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8141
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8142
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8143
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8144
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8145
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8146
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8147
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8148
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8149
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8150
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8151
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8152
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8153
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8154
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8155
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8156
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8157
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8158
    }/*function_tod_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8159
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8160
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8161
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8162
 *TOD_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8163
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8164
    case function_tod_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8165
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8166
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8167
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8168
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8169
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8170
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8171
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8172
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8173
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8174
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8175
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8176
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8177
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8178
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8179
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8180
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8181
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8182
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8183
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8184
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8185
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8186
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8187
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8188
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8189
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8190
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8191
    }/*function_tod_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8192
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8193
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8194
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8195
 *TOD_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8196
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8197
    case function_tod_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8198
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8199
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8200
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8201
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8202
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8203
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8204
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8205
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8206
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8207
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8208
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8209
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8210
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8211
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8212
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8213
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8214
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8215
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8216
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8217
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8218
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8219
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8220
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8221
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8222
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8223
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8224
    }/*function_tod_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8225
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8226
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8227
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8228
 *TOD_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8229
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8230
    case function_tod_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8231
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8232
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8233
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8234
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8235
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8236
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8237
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8238
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8239
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8240
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8241
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8242
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8243
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8244
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8245
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8246
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8247
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8248
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8249
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8250
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8251
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8252
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8253
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8254
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8255
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8256
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8257
    }/*function_tod_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8258
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8259
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8260
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8261
 *DT_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8262
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8263
    case function_dt_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8264
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8265
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8266
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8267
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8268
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8269
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8270
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8271
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8272
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8273
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8274
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8275
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8276
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8277
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8278
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8279
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8280
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8281
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8282
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8283
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8284
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8285
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8286
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8287
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8288
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8289
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8290
    }/*function_dt_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8291
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8292
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8293
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8294
 *DT_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8295
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8296
    case function_dt_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8297
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8298
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8299
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8300
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8301
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8302
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8303
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8304
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8305
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8306
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8307
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8308
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8309
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8310
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8311
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8312
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8313
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8314
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8315
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8316
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8317
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8318
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8319
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8320
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8321
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8322
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8323
    }/*function_dt_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8324
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8325
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8326
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8327
 *DT_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8328
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8329
    case function_dt_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8330
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8331
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8332
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8333
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8334
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8335
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8336
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8337
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8338
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8339
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8340
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8341
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8342
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8343
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8344
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8345
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8346
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8347
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8348
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8349
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8350
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8351
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8352
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8353
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8354
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8355
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8356
    }/*function_dt_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8357
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8358
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8359
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8360
 *DT_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8361
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8362
    case function_dt_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8363
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8364
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8365
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8366
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8367
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8368
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8369
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8370
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8371
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8372
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8373
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8374
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8375
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8376
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8377
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8378
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8379
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8380
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8381
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8382
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8383
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8384
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8385
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8386
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8387
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8388
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8389
    }/*function_dt_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8390
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8391
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8392
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8393
 *DT_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8394
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8395
    case function_dt_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8396
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8397
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8398
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8399
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8400
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8401
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8402
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8403
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8404
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8405
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8406
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8407
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8408
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8409
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8410
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8411
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8412
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8413
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8414
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8415
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8416
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8417
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8418
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8419
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8420
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8421
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8422
    }/*function_dt_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8423
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8424
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8425
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8426
 *DT_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8427
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8428
    case function_dt_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8429
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8430
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8431
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8432
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8433
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8434
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8435
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8436
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8437
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8438
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8439
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8440
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8441
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8442
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8443
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8444
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8445
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8446
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8447
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8448
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8449
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8450
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8451
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8452
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8453
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8454
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8455
    }/*function_dt_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8456
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8457
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8458
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8459
 *DT_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8460
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8461
    case function_dt_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8462
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8463
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8464
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8465
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8466
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8467
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8468
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8469
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8470
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8471
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8472
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8473
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8474
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8475
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8476
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8477
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8478
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8479
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8480
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8481
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8482
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8483
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8484
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8485
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8486
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8487
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8488
    }/*function_dt_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8489
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8490
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8491
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8492
 *DT_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8493
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8494
    case function_dt_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8495
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8496
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8497
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8498
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8499
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8500
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8501
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8502
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8503
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8504
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8505
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8506
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8507
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8508
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8509
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8510
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8511
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8512
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8513
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8514
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8515
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8516
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8517
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8518
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8519
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8520
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8521
    }/*function_dt_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8522
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8523
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8524
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8525
 *DT_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8526
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8527
    case function_dt_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8528
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8529
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8530
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8531
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8532
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8533
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8534
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8535
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8536
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8537
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8538
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8539
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8540
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8541
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8542
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8543
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8544
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8545
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8546
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8547
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8548
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8549
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8550
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8551
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8552
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8553
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8554
    }/*function_dt_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8555
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8556
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8557
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8558
 *DT_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8559
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8560
    case function_dt_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8561
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8562
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8563
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8564
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8565
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8566
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8567
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8568
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8569
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8570
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8571
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8572
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8573
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8574
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8575
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8576
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8577
                s4o.print(")__time_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8578
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8579
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8580
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8581
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8582
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8583
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8584
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8585
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8586
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8587
    }/*function_dt_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8588
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8589
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8590
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8591
 *DT_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8592
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8593
    case function_dt_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8594
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8595
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8596
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8597
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8598
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8599
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8600
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8601
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8602
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8603
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8604
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8605
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8606
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8607
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8608
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8609
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8610
                s4o.print(")__dt_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8611
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8612
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8613
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8614
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8615
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8616
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8617
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8618
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8619
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8620
    }/*function_dt_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8621
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8622
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8623
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8624
 *DT_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8625
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8626
    case function_dt_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8627
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8628
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8629
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8630
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8631
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8632
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8633
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8634
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8635
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8636
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8637
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8638
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8639
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8640
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8641
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8642
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8643
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8644
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8645
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8646
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8647
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8648
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8649
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8650
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8651
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8652
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8653
    }/*function_dt_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8654
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8655
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8656
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8657
 *DT_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8658
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8659
    case function_dt_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8660
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8661
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8662
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8663
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8664
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8665
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8666
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8667
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8668
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8669
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8670
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8671
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8672
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8673
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8674
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8675
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8676
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8677
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8678
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8679
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8680
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8681
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8682
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8683
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8684
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8685
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8686
    }/*function_dt_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8687
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8688
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8689
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8690
 *DT_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8691
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8692
    case function_dt_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8693
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8694
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8695
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8696
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8697
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8698
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8699
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8700
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8701
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8702
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8703
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8704
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8705
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8706
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8707
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8708
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8709
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8710
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8711
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8712
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8713
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8714
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8715
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8716
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8717
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8718
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8719
    }/*function_dt_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8720
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8721
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8722
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8723
 *DT_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8724
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8725
    case function_dt_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8726
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8727
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8728
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8729
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8730
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8731
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8732
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8733
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8734
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8735
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8736
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8737
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8738
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8739
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8740
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8741
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8742
                s4o.print(")__time_to_int(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8743
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8744
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8745
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8746
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8747
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8748
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8749
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8750
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8751
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8752
    }/*function_dt_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8753
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8754
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8755
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8756
 *STRING_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8757
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8758
    case function_string_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8759
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8760
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8761
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8762
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8763
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8764
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8765
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8766
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8767
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8768
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8769
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8770
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8771
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8772
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8773
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8774
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8775
                s4o.print(")__string_to_bool(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8776
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8777
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8778
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8779
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8780
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8781
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8782
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8783
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8784
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8785
    }/*function_string_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8786
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8787
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8788
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8789
 *STRING_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8790
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8791
    case function_string_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8792
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8793
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8794
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8795
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8796
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8797
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8798
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8799
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8800
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8801
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8802
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8803
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8804
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8805
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8806
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8807
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8808
                s4o.print(")__string_to_sint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8809
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8810
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8811
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8812
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8813
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8814
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8815
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8816
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8817
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8818
    }/*function_string_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8819
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8820
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8821
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8822
 *STRING_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8823
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8824
    case function_string_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8825
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8826
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8827
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8828
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8829
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8830
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8831
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8832
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8833
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8834
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8835
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8836
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8837
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8838
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8839
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8840
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8841
                s4o.print(")__string_to_sint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8842
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8843
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8844
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8845
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8846
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8847
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8848
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8849
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8850
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8851
    }/*function_string_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8852
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8853
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8854
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8855
 *STRING_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8856
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8857
    case function_string_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8858
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8859
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8860
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8861
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8862
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8863
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8864
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8865
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8866
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8867
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8868
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8869
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8870
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8871
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8872
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8873
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8874
                s4o.print(")__string_to_sint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8875
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8876
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8877
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8878
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8879
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8880
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8881
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8882
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8883
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8884
    }/*function_string_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8885
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8886
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8887
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8888
 *STRING_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8889
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8890
    case function_string_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8891
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8892
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8893
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8894
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8895
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8896
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8897
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8898
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8899
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8900
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8901
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8902
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8903
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8904
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8905
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8906
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8907
                s4o.print(")__string_to_sint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8908
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8909
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8910
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8911
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8912
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8913
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8914
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8915
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8916
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8917
    }/*function_string_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8918
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8919
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8920
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8921
 *STRING_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8922
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8923
    case function_string_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8924
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8925
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8926
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8927
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8928
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8929
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8930
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8931
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8932
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8933
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8934
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8935
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8936
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8937
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8938
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8939
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8940
                s4o.print(")__string_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8941
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8942
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8943
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8944
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8945
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8946
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8947
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8948
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8949
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8950
    }/*function_string_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8951
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8952
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8953
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8954
 *STRING_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8955
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8956
    case function_string_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8957
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8958
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8959
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8960
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8961
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8962
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8963
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8964
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8965
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8966
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8967
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8968
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8969
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8970
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8971
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8972
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8973
                s4o.print(")__string_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8974
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8975
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8976
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8977
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8978
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8979
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8980
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8981
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8982
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8983
    }/*function_string_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8984
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8985
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8986
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8987
 *STRING_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8988
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8989
    case function_string_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8990
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8991
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8992
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8993
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8994
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8995
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8996
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8997
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8998
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  8999
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9000
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9001
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9002
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9003
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9004
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9005
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9006
                s4o.print(")__string_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9007
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9008
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9009
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9010
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9011
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9012
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9013
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9014
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9015
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9016
    }/*function_string_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9017
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9018
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9019
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9020
 *STRING_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9021
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9022
    case function_string_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9023
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9024
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9025
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9026
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9027
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9028
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9029
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9030
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9031
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9032
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9033
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9034
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9035
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9036
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9037
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9038
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9039
                s4o.print(")__string_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9040
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9041
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9042
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9043
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9044
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9045
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9046
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9047
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9048
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9049
    }/*function_string_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9050
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9051
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9052
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9053
 *STRING_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9054
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9055
    case function_string_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9056
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9057
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9058
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9059
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9060
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9061
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9062
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9063
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9064
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9065
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9066
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9067
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9068
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9069
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9070
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9071
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9072
                s4o.print(")__string_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9073
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9074
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9075
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9076
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9077
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9078
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9079
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9080
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9081
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9082
    }/*function_string_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9083
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9084
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9085
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9086
 *STRING_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9087
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9088
    case function_string_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9089
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9090
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9091
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9092
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9093
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9094
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9095
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9096
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9097
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9098
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9099
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9100
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9101
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9102
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9103
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9104
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9105
                s4o.print(")__string_to_real(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9106
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9107
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9108
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9109
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9110
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9111
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9112
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9113
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9114
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9115
    }/*function_string_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9116
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9117
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9118
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9119
 *STRING_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9120
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9121
    case function_string_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9122
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9123
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9124
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9125
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9126
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9127
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9128
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9129
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9130
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9131
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9132
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9133
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9134
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9135
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9136
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9137
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9138
                s4o.print(")__string_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9139
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9140
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9141
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9142
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9143
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9144
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9145
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9146
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9147
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9148
    }/*function_string_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9149
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9150
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9151
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9152
 *STRING_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9153
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9154
    case function_string_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9155
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9156
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9157
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9158
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9159
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9160
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9161
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9162
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9163
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9164
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9165
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9166
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9167
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9168
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9169
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9170
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9171
                s4o.print(")__string_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9172
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9173
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9174
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9175
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9176
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9177
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9178
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9179
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9180
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9181
    }/*function_string_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9182
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9183
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9184
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9185
 *STRING_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9186
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9187
    case function_string_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9188
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9189
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9190
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9191
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9192
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9193
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9194
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9195
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9196
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9197
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9198
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9199
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9200
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9201
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9202
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9203
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9204
                s4o.print(")__string_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9205
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9206
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9207
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9208
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9209
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9210
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9211
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9212
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9213
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9214
    }/*function_string_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9215
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9216
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9217
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9218
 *STRING_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9219
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9220
    case function_string_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9221
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9222
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9223
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9224
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9225
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9226
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9227
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9228
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9229
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9230
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9231
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9232
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9233
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9234
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9235
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9236
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9237
                s4o.print(")__string_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9238
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9239
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9240
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9241
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9242
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9243
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9244
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9245
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9246
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9247
    }/*function_string_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9248
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9249
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9250
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9251
 *STRING_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9252
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9253
    case function_string_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9254
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9255
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9256
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9257
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9258
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9259
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9260
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9261
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9262
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9263
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9264
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9265
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9266
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9267
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9268
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9269
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9270
                s4o.print(")__string_to_bit(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9271
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9272
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9273
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9274
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9275
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9276
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9277
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9278
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9279
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9280
    }/*function_string_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9281
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9282
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9283
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9284
 *STRING_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9285
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9286
    case function_string_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9287
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9288
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9289
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9290
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9291
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9292
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9293
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9294
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9295
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9296
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9297
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9298
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9299
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9300
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9301
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9302
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9303
                s4o.print(")__string_to_bit(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9304
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9305
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9306
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9307
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9308
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9309
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9310
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9311
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9312
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9313
    }/*function_string_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9314
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9315
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9316
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9317
 *STRING_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9318
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9319
    case function_string_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9320
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9321
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9322
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9323
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9324
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9325
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9326
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9327
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9328
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9329
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9330
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9331
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9333
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9334
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9335
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9336
                s4o.print(")__string_to_bit(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9337
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9338
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9339
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9340
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9341
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9342
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9343
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9344
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9345
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9346
    }/*function_string_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9347
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9348
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9349
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9350
 *STRING_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9351
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9352
    case function_string_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9353
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9354
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9355
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9356
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9357
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9358
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9359
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9360
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9361
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9362
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9363
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9364
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9365
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9366
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9367
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9368
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9369
                s4o.print(")__string_to_bit(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9370
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9371
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9372
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9373
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9374
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9375
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9376
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9377
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9378
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9379
    }/*function_string_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9380
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9381
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9382
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9383
 *BYTE_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9384
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9385
    case function_byte_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9386
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9387
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9388
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9389
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9390
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9391
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9392
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9393
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9394
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9395
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9396
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9397
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9398
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9399
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9400
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9401
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9402
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9403
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9404
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9405
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9406
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9407
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9408
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9409
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9410
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9411
    }/*function_byte_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9412
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9413
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9414
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9415
 *BYTE_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9416
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9417
    case function_byte_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9418
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9419
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9420
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9421
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9422
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9423
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9424
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9425
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9426
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9427
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9428
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9429
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9430
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9431
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9432
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9433
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9434
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9435
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9436
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9437
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9438
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9439
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9440
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9441
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9442
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9443
    }/*function_byte_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9444
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9445
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9446
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9447
 *BYTE_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9448
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9449
    case function_byte_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9450
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9451
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9452
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9453
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9454
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9455
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9456
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9457
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9458
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9459
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9460
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9461
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9462
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9463
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9464
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9465
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9466
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9467
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9468
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9469
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9470
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9471
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9472
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9473
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9474
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9475
    }/*function_byte_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9476
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9477
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9478
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9479
 *BYTE_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9480
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9481
    case function_byte_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9482
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9483
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9484
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9485
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9486
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9487
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9488
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9489
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9490
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9491
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9492
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9493
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9494
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9495
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9496
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9497
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9498
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9499
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9500
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9501
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9502
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9503
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9504
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9505
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9506
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9507
    }/*function_byte_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9508
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9509
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9510
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9511
 *BYTE_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9512
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9513
    case function_byte_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9514
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9515
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9516
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9517
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9518
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9519
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9520
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9521
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9522
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9523
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9524
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9525
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9526
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9527
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9528
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9529
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9530
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9531
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9532
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9533
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9534
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9535
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9536
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9537
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9538
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9539
    }/*function_byte_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9540
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9541
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9542
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9543
 *BYTE_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9544
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9545
    case function_byte_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9546
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9547
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9548
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9549
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9550
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9551
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9552
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9553
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9554
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9555
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9556
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9557
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9558
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9559
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9560
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9561
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9562
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9563
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9564
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9565
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9566
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9567
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9568
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9569
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9570
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9571
    }/*function_byte_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9572
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9573
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9574
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9575
 *BYTE_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9576
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9577
    case function_byte_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9578
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9579
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9580
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9581
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9582
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9583
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9584
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9585
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9586
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9587
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9588
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9589
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9590
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9591
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9592
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9593
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9594
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9595
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9596
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9597
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9598
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9599
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9600
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9601
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9602
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9603
    }/*function_byte_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9604
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9605
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9606
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9607
 *BYTE_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9608
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9609
    case function_byte_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9610
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9611
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9612
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9613
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9614
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9615
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9616
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9617
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9618
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9619
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9620
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9621
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9622
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9623
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9624
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9625
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9626
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9627
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9628
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9629
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9630
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9631
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9632
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9633
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9634
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9635
    }/*function_byte_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9636
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9637
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9638
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9639
 *BYTE_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9640
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9641
    case function_byte_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9642
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9643
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9644
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9645
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9646
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9647
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9648
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9649
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9650
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9651
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9652
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9653
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9654
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9655
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9656
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9657
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9658
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9659
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9660
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9661
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9662
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9663
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9664
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9665
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9666
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9667
    }/*function_byte_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9668
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9669
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9670
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9671
 *BYTE_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9672
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9673
    case function_byte_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9674
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9675
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9676
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9677
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9678
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9679
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9680
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9681
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9682
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9683
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9684
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9685
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9686
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9687
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9688
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9689
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9690
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9691
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9692
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9693
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9694
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9695
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9696
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9697
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9698
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9699
    }/*function_byte_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9700
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9701
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9702
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9703
 *BYTE_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9704
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9705
    case function_byte_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9706
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9707
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9708
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9709
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9710
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9711
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9712
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9713
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9714
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9715
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9716
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9717
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9718
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9719
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9720
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9721
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9722
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9723
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9724
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9725
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9726
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9727
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9728
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9729
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9730
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9731
    }/*function_byte_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9732
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9733
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9734
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9735
 *BYTE_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9736
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9737
    case function_byte_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9738
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9739
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9740
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9741
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9742
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9743
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9744
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9745
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9746
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9747
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9748
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9749
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9750
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9751
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9752
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9753
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9754
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9755
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9756
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9757
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9758
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9759
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9760
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9761
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9762
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9763
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9764
    }/*function_byte_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9765
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9766
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9767
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9768
 *BYTE_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9769
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9770
    case function_byte_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9771
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9772
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9773
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9774
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9775
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9776
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9777
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9778
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9779
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9780
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9781
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9782
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9783
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9784
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9785
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9786
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9787
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9788
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9789
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9790
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9791
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9792
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9793
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9794
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9795
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9796
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9797
    }/*function_byte_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9798
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9799
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9800
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9801
 *BYTE_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9802
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9803
    case function_byte_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9804
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9805
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9806
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9807
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9808
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9809
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9810
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9811
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9812
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9813
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9814
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9815
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9816
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9817
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9818
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9819
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9820
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9821
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9822
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9823
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9824
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9825
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9826
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9827
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9828
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9829
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9830
    }/*function_byte_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9831
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9832
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9833
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9834
 *BYTE_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9835
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9836
    case function_byte_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9837
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9838
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9839
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9840
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9841
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9842
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9843
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9844
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9845
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9846
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9847
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9848
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9849
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9850
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9851
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9852
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9853
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9854
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9855
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9856
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9857
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9858
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9859
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9860
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9861
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9862
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9863
    }/*function_byte_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9864
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9865
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9866
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9867
 *BYTE_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9868
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9869
    case function_byte_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9870
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9871
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9872
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9873
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9874
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9875
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9876
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9877
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9878
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9879
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9880
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9881
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9882
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9883
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9884
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9885
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9886
                s4o.print(")__bit_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9887
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9888
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9889
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9890
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9891
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9892
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9893
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9894
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9895
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9896
    }/*function_byte_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9897
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9898
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9899
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9900
 *BYTE_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9901
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9902
    case function_byte_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9903
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9904
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9905
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9906
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9907
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9908
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9909
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9910
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9911
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9912
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9913
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9914
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9915
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9916
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9917
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9918
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9919
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9920
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9921
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9922
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9923
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9924
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9925
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9926
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9927
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9928
    }/*function_byte_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9929
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9930
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9931
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9932
 *BYTE_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9933
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9934
    case function_byte_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9935
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9936
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9937
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9938
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9939
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9940
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9941
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9942
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9943
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9944
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9945
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9946
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9947
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9948
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9949
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9950
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9951
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9952
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9953
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9954
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9955
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9956
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9957
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9958
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9959
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9960
    }/*function_byte_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9961
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9962
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9963
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9964
 *BYTE_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9965
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9966
    case function_byte_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9967
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9968
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9969
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9970
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9971
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9972
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9973
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9974
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9975
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9976
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9977
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9978
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9979
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9980
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9981
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9982
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9983
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9984
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9985
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9986
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9987
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9988
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9989
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9990
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9991
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9992
    }/*function_byte_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9993
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9994
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9995
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9996
 *WORD_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9997
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9998
    case function_word_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
  9999
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10000
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10001
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10002
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10003
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10004
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10005
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10006
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10007
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10008
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10009
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10010
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10011
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10012
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10013
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10014
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10015
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10016
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10017
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10018
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10019
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10020
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10021
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10022
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10023
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10024
    }/*function_word_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10025
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10026
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10027
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10028
 *WORD_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10029
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10030
    case function_word_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10031
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10032
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10033
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10034
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10035
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10036
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10037
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10038
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10039
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10040
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10041
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10042
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10043
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10044
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10045
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10046
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10047
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10048
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10049
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10050
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10051
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10052
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10053
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10054
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10055
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10056
    }/*function_word_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10057
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10058
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10059
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10060
 *WORD_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10061
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10062
    case function_word_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10063
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10064
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10065
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10066
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10067
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10068
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10069
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10070
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10071
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10072
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10073
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10074
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10075
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10076
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10077
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10078
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10079
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10080
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10081
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10082
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10083
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10084
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10085
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10086
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10087
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10088
    }/*function_word_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10089
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10090
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10091
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10092
 *WORD_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10093
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10094
    case function_word_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10095
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10096
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10097
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10098
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10099
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10100
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10101
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10102
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10103
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10104
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10105
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10106
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10107
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10108
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10109
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10110
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10111
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10112
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10113
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10114
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10115
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10116
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10117
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10118
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10119
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10120
    }/*function_word_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10121
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10122
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10123
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10124
 *WORD_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10125
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10126
    case function_word_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10127
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10128
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10129
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10130
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10131
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10132
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10133
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10134
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10135
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10136
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10137
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10138
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10139
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10140
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10141
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10142
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10143
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10144
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10145
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10146
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10147
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10148
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10149
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10150
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10151
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10152
    }/*function_word_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10153
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10154
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10155
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10156
 *WORD_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10157
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10158
    case function_word_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10159
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10160
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10161
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10162
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10163
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10164
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10165
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10166
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10167
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10168
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10169
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10170
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10171
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10172
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10173
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10174
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10175
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10176
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10177
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10178
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10179
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10180
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10181
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10182
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10183
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10184
    }/*function_word_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10185
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10186
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10187
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10188
 *WORD_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10189
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10190
    case function_word_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10191
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10192
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10193
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10194
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10195
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10196
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10197
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10198
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10199
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10200
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10201
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10202
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10203
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10204
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10205
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10206
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10207
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10208
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10209
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10210
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10211
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10212
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10213
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10214
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10215
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10216
    }/*function_word_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10217
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10218
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10219
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10220
 *WORD_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10221
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10222
    case function_word_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10223
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10224
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10225
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10226
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10227
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10228
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10229
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10230
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10231
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10232
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10233
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10234
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10235
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10236
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10237
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10238
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10239
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10240
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10241
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10242
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10243
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10244
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10245
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10246
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10247
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10248
    }/*function_word_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10249
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10250
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10251
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10252
 *WORD_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10253
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10254
    case function_word_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10255
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10256
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10257
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10258
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10259
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10260
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10261
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10262
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10263
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10264
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10265
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10266
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10267
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10268
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10269
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10270
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10271
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10272
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10273
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10274
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10275
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10276
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10277
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10278
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10279
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10280
    }/*function_word_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10281
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10282
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10283
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10284
 *WORD_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10285
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10286
    case function_word_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10287
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10288
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10289
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10290
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10291
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10292
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10293
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10294
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10295
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10296
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10297
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10298
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10299
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10300
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10301
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10302
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10303
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10304
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10305
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10306
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10307
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10308
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10309
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10310
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10311
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10312
    }/*function_word_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10313
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10314
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10315
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10316
 *WORD_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10317
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10318
    case function_word_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10319
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10320
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10321
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10322
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10323
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10324
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10325
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10326
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10327
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10328
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10329
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10330
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10331
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10332
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10333
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10334
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10335
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10336
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10337
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10338
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10339
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10340
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10341
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10342
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10343
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10344
    }/*function_word_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10345
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10346
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10347
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10348
 *WORD_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10349
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10350
    case function_word_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10351
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10352
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10353
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10354
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10355
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10356
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10357
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10358
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10359
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10360
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10361
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10362
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10363
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10364
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10365
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10366
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10367
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10368
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10369
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10370
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10371
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10372
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10373
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10374
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10375
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10376
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10377
    }/*function_word_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10378
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10379
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10380
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10381
 *WORD_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10382
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10383
    case function_word_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10384
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10385
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10386
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10387
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10388
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10389
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10390
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10391
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10392
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10393
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10394
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10395
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10396
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10397
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10398
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10399
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10400
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10401
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10402
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10403
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10404
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10405
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10406
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10407
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10408
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10409
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10410
    }/*function_word_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10411
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10412
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10413
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10414
 *WORD_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10415
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10416
    case function_word_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10417
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10418
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10420
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10421
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10422
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10423
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10424
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10425
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10426
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10427
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10428
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10429
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10430
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10431
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10432
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10433
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10434
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10435
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10436
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10437
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10438
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10439
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10440
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10441
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10442
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10443
    }/*function_word_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10444
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10445
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10446
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10447
 *WORD_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10448
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10449
    case function_word_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10450
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10451
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10452
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10453
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10454
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10455
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10456
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10457
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10458
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10459
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10460
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10461
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10462
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10463
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10464
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10465
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10466
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10467
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10468
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10469
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10470
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10471
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10472
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10473
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10474
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10475
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10476
    }/*function_word_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10477
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10478
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10479
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10480
 *WORD_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10481
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10482
    case function_word_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10483
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10484
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10485
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10486
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10487
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10488
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10489
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10490
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10491
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10492
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10493
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10494
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10495
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10496
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10497
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10498
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10499
                s4o.print(")__bit_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10500
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10501
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10502
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10503
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10504
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10505
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10506
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10507
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10508
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10509
    }/*function_word_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10510
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10511
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10512
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10513
 *WORD_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10514
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10515
    case function_word_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10516
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10517
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10518
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10519
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10520
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10521
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10522
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10523
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10524
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10525
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10526
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10527
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10528
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10529
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10530
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10531
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10532
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10533
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10534
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10535
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10536
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10537
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10538
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10539
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10540
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10541
    }/*function_word_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10542
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10543
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10544
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10545
 *WORD_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10546
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10547
    case function_word_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10548
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10549
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10550
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10551
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10552
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10553
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10554
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10555
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10556
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10557
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10558
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10559
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10560
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10561
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10562
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10563
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10564
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10565
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10566
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10567
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10568
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10569
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10570
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10571
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10572
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10573
    }/*function_word_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10574
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10575
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10576
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10577
 *WORD_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10578
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10579
    case function_word_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10580
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10581
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10582
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10583
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10584
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10585
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10586
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10587
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10588
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10589
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10590
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10591
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10592
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10593
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10594
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10595
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10596
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10597
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10598
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10599
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10600
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10601
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10602
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10603
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10604
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10605
    }/*function_word_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10606
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10607
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10608
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10609
 *DWORD_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10610
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10611
    case function_dword_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10612
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10613
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10614
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10615
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10616
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10617
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10618
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10619
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10620
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10621
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10622
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10623
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10624
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10625
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10626
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10627
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10628
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10629
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10630
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10631
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10632
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10633
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10634
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10635
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10636
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10637
    }/*function_dword_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10638
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10639
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10640
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10641
 *DWORD_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10642
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10643
    case function_dword_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10644
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10645
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10646
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10647
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10648
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10649
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10650
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10651
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10652
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10653
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10654
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10655
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10656
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10657
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10658
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10659
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10660
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10661
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10662
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10663
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10664
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10665
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10666
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10667
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10668
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10669
    }/*function_dword_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10670
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10671
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10672
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10673
 *DWORD_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10674
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10675
    case function_dword_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10676
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10677
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10678
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10679
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10680
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10681
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10682
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10683
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10684
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10685
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10686
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10687
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10688
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10689
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10690
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10691
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10692
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10693
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10694
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10695
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10696
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10697
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10698
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10699
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10700
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10701
    }/*function_dword_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10702
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10703
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10704
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10705
 *DWORD_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10706
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10707
    case function_dword_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10708
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10709
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10710
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10711
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10712
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10713
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10714
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10715
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10716
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10717
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10718
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10719
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10720
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10721
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10722
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10723
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10724
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10725
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10726
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10727
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10728
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10729
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10730
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10731
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10732
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10733
    }/*function_dword_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10734
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10735
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10736
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10737
 *DWORD_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10738
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10739
    case function_dword_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10740
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10741
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10742
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10743
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10744
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10745
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10746
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10747
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10748
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10749
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10750
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10751
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10752
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10753
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10754
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10755
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10756
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10757
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10758
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10759
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10760
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10761
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10762
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10763
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10764
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10765
    }/*function_dword_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10766
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10767
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10768
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10769
 *DWORD_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10770
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10771
    case function_dword_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10772
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10773
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10774
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10775
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10776
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10777
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10778
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10779
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10780
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10781
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10782
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10783
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10784
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10785
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10786
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10787
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10788
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10789
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10790
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10791
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10792
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10793
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10794
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10795
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10796
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10797
    }/*function_dword_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10798
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10799
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10800
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10801
 *DWORD_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10802
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10803
    case function_dword_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10804
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10805
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10806
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10807
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10808
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10809
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10810
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10811
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10812
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10813
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10814
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10815
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10816
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10817
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10818
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10819
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10820
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10821
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10822
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10823
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10824
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10825
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10826
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10827
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10828
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10829
    }/*function_dword_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10830
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10831
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10832
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10833
 *DWORD_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10834
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10835
    case function_dword_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10836
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10837
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10838
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10839
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10840
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10841
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10842
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10843
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10844
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10845
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10846
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10847
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10848
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10849
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10850
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10851
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10852
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10853
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10854
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10855
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10856
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10857
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10858
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10859
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10860
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10861
    }/*function_dword_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10862
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10863
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10864
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10865
 *DWORD_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10866
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10867
    case function_dword_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10868
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10869
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10870
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10871
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10872
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10873
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10874
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10875
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10876
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10877
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10878
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10879
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10880
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10881
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10882
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10883
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10884
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10885
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10886
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10887
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10888
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10889
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10890
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10891
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10892
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10893
    }/*function_dword_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10894
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10895
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10896
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10897
 *DWORD_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10898
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10899
    case function_dword_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10900
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10901
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10902
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10903
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10904
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10905
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10906
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10907
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10908
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10909
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10910
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10911
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10912
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10913
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10914
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10915
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10916
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10917
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10918
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10919
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10920
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10921
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10922
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10923
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10924
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10925
    }/*function_dword_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10926
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10927
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10928
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10929
 *DWORD_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10930
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10931
    case function_dword_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10932
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10933
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10934
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10935
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10936
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10937
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10938
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10939
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10940
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10941
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10942
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10943
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10944
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10945
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10946
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10947
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10948
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10949
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10950
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10951
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10952
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10953
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10954
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10955
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10956
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10957
    }/*function_dword_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10958
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10959
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10960
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10961
 *DWORD_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10962
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10963
    case function_dword_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10964
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10965
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10966
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10967
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10968
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10969
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10970
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10971
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10972
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10973
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10974
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10975
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10976
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10977
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10978
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10979
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10980
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10981
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10982
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10983
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10984
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10985
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10986
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10987
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10988
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10989
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10990
    }/*function_dword_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10991
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10992
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10993
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10994
 *DWORD_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10995
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10996
    case function_dword_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10997
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10998
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 10999
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11000
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11001
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11002
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11003
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11004
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11005
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11006
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11007
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11008
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11009
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11010
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11011
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11012
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11013
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11014
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11015
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11016
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11017
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11018
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11019
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11020
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11021
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11022
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11023
    }/*function_dword_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11024
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11025
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11026
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11027
 *DWORD_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11028
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11029
    case function_dword_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11030
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11031
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11032
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11033
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11034
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11035
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11036
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11037
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11038
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11039
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11040
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11041
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11042
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11043
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11044
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11045
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11046
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11047
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11048
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11049
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11050
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11051
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11052
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11053
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11054
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11055
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11056
    }/*function_dword_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11057
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11058
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11059
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11060
 *DWORD_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11061
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11062
    case function_dword_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11063
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11064
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11065
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11066
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11067
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11068
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11069
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11070
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11071
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11072
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11073
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11074
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11075
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11076
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11077
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11078
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11079
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11080
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11081
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11082
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11083
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11084
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11085
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11086
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11087
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11088
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11089
    }/*function_dword_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11090
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11091
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11092
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11093
 *DWORD_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11094
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11095
    case function_dword_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11096
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11097
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11098
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11099
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11100
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11101
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11102
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11103
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11104
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11105
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11106
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11107
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11108
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11109
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11110
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11111
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11112
                s4o.print(")__bit_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11113
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11114
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11115
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11116
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11117
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11118
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11119
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11120
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11121
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11122
    }/*function_dword_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11123
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11124
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11125
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11126
 *DWORD_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11127
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11128
    case function_dword_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11129
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11130
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11131
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11132
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11133
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11134
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11135
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11136
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11137
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11138
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11139
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11140
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11141
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11142
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11143
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11144
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11145
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11146
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11147
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11148
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11149
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11150
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11151
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11152
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11153
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11154
    }/*function_dword_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11155
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11156
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11157
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11158
 *DWORD_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11159
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11160
    case function_dword_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11161
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11162
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11163
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11164
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11165
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11166
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11167
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11168
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11169
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11170
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11171
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11172
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11173
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11174
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11175
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11176
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11177
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11178
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11179
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11180
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11181
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11182
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11183
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11184
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11185
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11186
    }/*function_dword_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11187
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11188
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11189
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11190
 *DWORD_TO_LWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11191
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11192
    case function_dword_to_lword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11193
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11194
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11195
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11196
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11197
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11198
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11199
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11200
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11201
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11202
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11203
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11204
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11205
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11206
                symbol_c * return_type_symbol = &search_constant_type_c::lword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11207
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11208
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11209
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11210
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11211
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11212
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11213
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11214
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11215
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11216
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11217
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11218
    }/*function_dword_to_lword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11219
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11220
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11221
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11222
 *LWORD_TO_BOOL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11223
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11224
    case function_lword_to_bool :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11225
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11226
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11227
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11228
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11229
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11230
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11231
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11232
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11233
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11234
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11235
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11236
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11237
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11238
                symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11239
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11240
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11241
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11242
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11243
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11244
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11245
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11246
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11247
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11248
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11249
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11250
    }/*function_lword_to_bool*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11251
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11252
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11253
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11254
 *LWORD_TO_SINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11255
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11256
    case function_lword_to_sint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11257
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11258
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11259
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11260
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11261
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11262
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11263
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11264
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11265
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11266
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11267
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11268
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11269
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11270
                symbol_c * return_type_symbol = &search_constant_type_c::sint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11271
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11272
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11273
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11274
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11275
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11276
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11277
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11278
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11279
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11280
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11281
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11282
    }/*function_lword_to_sint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11283
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11284
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11285
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11286
 *LWORD_TO_INT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11287
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11288
    case function_lword_to_int :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11289
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11290
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11291
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11292
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11293
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11294
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11295
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11296
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11297
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11298
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11299
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11300
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11301
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11302
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11303
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11304
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11305
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11306
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11307
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11308
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11309
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11310
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11311
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11312
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11313
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11314
    }/*function_lword_to_int*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11315
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11316
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11317
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11318
 *LWORD_TO_DINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11319
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11320
    case function_lword_to_dint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11321
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11322
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11323
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11324
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11325
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11326
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11327
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11328
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11329
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11330
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11331
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11332
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11333
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11334
                symbol_c * return_type_symbol = &search_constant_type_c::dint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11335
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11336
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11337
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11338
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11339
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11340
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11341
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11342
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11343
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11344
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11345
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11346
    }/*function_lword_to_dint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11347
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11348
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11349
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11350
 *LWORD_TO_LINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11351
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11352
    case function_lword_to_lint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11353
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11354
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11355
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11356
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11357
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11358
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11359
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11360
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11361
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11362
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11363
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11364
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11365
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11366
                symbol_c * return_type_symbol = &search_constant_type_c::lint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11367
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11368
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11369
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11370
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11371
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11372
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11373
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11374
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11375
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11376
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11377
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11378
    }/*function_lword_to_lint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11379
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11380
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11381
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11382
 *LWORD_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11383
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11384
    case function_lword_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11385
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11386
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11387
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11388
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11389
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11390
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11391
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11392
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11393
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11394
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11395
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11396
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11397
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11398
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11399
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11400
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11401
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11402
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11403
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11404
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11405
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11406
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11407
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11408
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11409
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11410
    }/*function_lword_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11411
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11412
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11413
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11414
 *LWORD_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11415
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11416
    case function_lword_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11417
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11418
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11420
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11421
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11422
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11423
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11424
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11425
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11426
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11427
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11428
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11429
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11430
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11431
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11432
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11433
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11434
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11435
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11436
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11437
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11438
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11439
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11440
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11441
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11442
    }/*function_lword_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11443
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11444
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11445
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11446
 *LWORD_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11447
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11448
    case function_lword_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11449
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11450
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11451
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11452
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11453
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11454
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11455
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11456
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11457
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11458
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11459
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11460
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11461
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11462
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11463
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11464
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11465
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11466
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11467
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11468
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11469
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11470
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11471
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11472
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11473
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11474
    }/*function_lword_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11475
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11476
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11477
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11478
 *LWORD_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11479
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11480
    case function_lword_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11481
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11482
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11483
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11484
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11485
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11486
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11487
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11488
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11489
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11490
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11491
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11492
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11493
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11494
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11495
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11496
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11497
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11498
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11499
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11500
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11501
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11502
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11503
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11504
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11505
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11506
    }/*function_lword_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11507
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11508
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11509
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11510
 *LWORD_TO_REAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11511
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11512
    case function_lword_to_real :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11513
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11514
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11515
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11516
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11517
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11518
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11519
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11520
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11521
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11522
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11523
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11524
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11525
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11526
                symbol_c * return_type_symbol = &search_constant_type_c::real_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11527
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11528
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11529
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11530
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11531
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11532
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11533
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11534
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11535
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11536
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11537
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11538
    }/*function_lword_to_real*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11539
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11540
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11541
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11542
 *LWORD_TO_LREAL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11543
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11544
    case function_lword_to_lreal :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11545
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11546
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11547
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11548
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11549
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11550
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11551
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11552
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11553
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11554
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11555
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11556
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11557
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11558
                symbol_c * return_type_symbol = &search_constant_type_c::lreal_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11559
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11560
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11561
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11562
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11563
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11564
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11565
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11566
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11567
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11568
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11569
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11570
    }/*function_lword_to_lreal*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11571
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11572
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11573
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11574
 *LWORD_TO_TIME
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11575
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11576
    case function_lword_to_time :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11577
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11578
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11579
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11580
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11581
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11582
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11583
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11584
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11585
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11586
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11587
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11588
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11589
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11590
                symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11591
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11592
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11593
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11594
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11595
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11596
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11597
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11598
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11599
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11600
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11601
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11602
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11603
    }/*function_lword_to_time*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11604
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11605
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11606
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11607
 *LWORD_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11608
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11609
    case function_lword_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11610
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11611
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11612
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11613
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11614
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11615
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11616
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11617
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11618
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11619
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11620
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11621
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11622
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11623
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11624
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11625
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11626
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11627
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11628
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11629
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11630
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11631
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11632
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11633
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11634
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11635
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11636
    }/*function_lword_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11637
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11638
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11639
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11640
 *LWORD_TO_TOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11641
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11642
    case function_lword_to_tod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11643
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11644
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11645
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11646
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11647
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11648
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11649
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11650
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11651
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11652
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11653
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11654
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11655
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11656
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11657
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11658
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11659
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11660
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11661
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11662
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11663
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11664
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11665
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11666
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11667
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11668
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11669
    }/*function_lword_to_tod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11670
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11671
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11672
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11673
 *LWORD_TO_DT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11674
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11675
    case function_lword_to_dt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11676
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11677
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11678
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11679
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11680
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11681
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11682
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11683
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11684
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11685
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11686
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11687
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11688
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11689
                symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11690
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11691
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11692
                s4o.print(")__int_to_time(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11693
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11694
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11695
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11696
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11697
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11698
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11699
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11700
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11701
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11702
    }/*function_lword_to_dt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11703
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11704
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11705
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11706
 *LWORD_TO_STRING
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11707
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11708
    case function_lword_to_string :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11709
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11710
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11711
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11712
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11713
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11714
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11715
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11716
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11717
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11718
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11719
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11720
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11721
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11722
                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11723
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11724
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11725
                s4o.print(")__bit_to_string(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11726
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11727
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11728
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11729
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11730
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11731
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11732
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11733
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11734
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11735
    }/*function_lword_to_string*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11736
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11737
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11738
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11739
 *LWORD_TO_BYTE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11740
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11741
    case function_lword_to_byte :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11742
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11743
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11744
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11745
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11746
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11747
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11748
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11749
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11750
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11751
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11752
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11753
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11754
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11755
                symbol_c * return_type_symbol = &search_constant_type_c::byte_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11756
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11757
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11758
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11759
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11760
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11761
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11762
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11763
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11764
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11765
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11766
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11767
    }/*function_lword_to_byte*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11768
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11769
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11770
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11771
 *LWORD_TO_WORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11772
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11773
    case function_lword_to_word :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11774
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11775
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11776
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11777
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11778
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11779
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11780
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11781
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11782
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11783
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11784
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11785
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11786
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11787
                symbol_c * return_type_symbol = &search_constant_type_c::word_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11788
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11789
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11790
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11791
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11792
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11793
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11794
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11795
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11796
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11797
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11798
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11799
    }/*function_lword_to_word*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11800
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11801
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11802
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11803
 *LWORD_TO_DWORD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11804
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11805
    case function_lword_to_dword :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11806
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11807
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11808
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11809
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11810
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11811
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11812
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11813
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11814
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11815
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11816
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11817
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11818
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11819
                symbol_c * return_type_symbol = &search_constant_type_c::dword_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11820
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11821
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11822
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11823
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11824
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11825
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11826
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11827
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11828
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11829
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11830
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11831
    }/*function_lword_to_dword*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11832
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11833
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11834
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11835
 *TRUNC
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11836
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11837
    case function_trunc :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11838
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11839
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11840
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11841
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11842
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11843
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11844
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11845
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11846
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11847
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11848
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11849
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11850
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11851
                symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11852
                s4o.print("(int)");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11853
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11854
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11855
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11856
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11857
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11858
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11859
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11860
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11861
    }/*function_trunc*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11862
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11863
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11864
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11865
 *BCD_TO_USINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11866
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11867
    case function_bcd_to_usint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11868
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11869
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11870
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11871
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11872
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11873
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11874
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11875
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11876
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11877
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11878
            if(search_expression_type->is_same_type(&search_constant_type_c::byte_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11879
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11880
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11881
                symbol_c * return_type_symbol = &search_constant_type_c::usint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11882
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11883
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11884
                s4o.print(")__bcd_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11885
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11886
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11887
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11888
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11889
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11890
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11891
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11892
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11893
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11894
    }/*function_bcd_to_usint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11895
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11896
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11897
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11898
 *BCD_TO_UINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11899
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11900
    case function_bcd_to_uint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11901
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11902
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11903
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11904
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11905
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11906
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11907
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11908
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11909
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11910
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11911
            if(search_expression_type->is_same_type(&search_constant_type_c::word_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11912
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11913
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11914
                symbol_c * return_type_symbol = &search_constant_type_c::uint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11915
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11916
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11917
                s4o.print(")__bcd_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11918
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11919
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11920
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11921
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11922
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11923
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11924
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11925
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11926
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11927
    }/*function_bcd_to_uint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11928
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11929
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11930
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11931
 *BCD_TO_UDINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11932
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11933
    case function_bcd_to_udint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11934
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11935
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11936
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11937
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11938
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11939
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11940
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11941
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11942
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11943
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11944
            if(search_expression_type->is_same_type(&search_constant_type_c::dword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11945
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11946
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11947
                symbol_c * return_type_symbol = &search_constant_type_c::udint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11948
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11949
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11950
                s4o.print(")__bcd_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11951
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11952
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11953
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11954
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11955
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11956
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11957
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11958
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11959
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11960
    }/*function_bcd_to_udint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11961
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11962
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11963
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11964
 *BCD_TO_ULINT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11965
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11966
    case function_bcd_to_ulint :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11967
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11968
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11969
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11970
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11971
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11972
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11973
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11974
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11975
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11976
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11977
            if(search_expression_type->is_same_type(&search_constant_type_c::lword_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11978
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11979
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11980
                symbol_c * return_type_symbol = &search_constant_type_c::ulint_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11981
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11982
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11983
                s4o.print(")__bcd_to_uint(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11984
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11985
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11986
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11987
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11988
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11989
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11990
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11991
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11992
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11993
    }/*function_bcd_to_ulint*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11994
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11995
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11996
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11997
 *USINT_TO_BCD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11998
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 11999
    case function_usint_to_bcd :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12000
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12001
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12002
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12003
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12004
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12005
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12006
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12007
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12008
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12009
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12010
            if(search_expression_type->is_same_type(&search_constant_type_c::usint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12011
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12012
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12013
                symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12014
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12015
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12016
                s4o.print(")__uint_to_bcd(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12017
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12018
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12019
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12020
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12021
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12022
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12023
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12024
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12025
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12026
    }/*function_usint_to_bcd*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12027
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12028
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12029
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12030
 *UINT_TO_BCD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12031
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12032
    case function_uint_to_bcd :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12033
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12034
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12035
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12036
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12037
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12038
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12039
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12040
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12041
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12042
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12043
            if(search_expression_type->is_same_type(&search_constant_type_c::uint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12044
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12045
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12046
                symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12047
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12048
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12049
                s4o.print(")__uint_to_bcd(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12050
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12051
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12052
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12053
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12054
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12055
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12056
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12057
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12058
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12059
    }/*function_uint_to_bcd*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12060
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12061
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12062
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12063
 *UDINT_TO_BCD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12064
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12065
    case function_udint_to_bcd :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12066
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12067
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12068
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12069
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12070
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12071
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12072
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12073
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12074
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12075
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12076
            if(search_expression_type->is_same_type(&search_constant_type_c::udint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12077
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12078
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12079
                symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12080
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12081
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12082
                s4o.print(")__uint_to_bcd(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12083
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12084
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12085
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12086
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12087
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12088
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12089
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12090
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12091
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12092
    }/*function_udint_to_bcd*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12093
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12094
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12095
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12096
 *ULINT_TO_BCD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12097
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12098
    case function_ulint_to_bcd :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12099
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12100
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12101
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12102
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12103
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12104
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12105
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12106
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12107
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12108
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12109
            if(search_expression_type->is_same_type(&search_constant_type_c::ulint_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12110
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12111
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12112
                symbol_c * return_type_symbol = &search_constant_type_c::constant_int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12113
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12114
                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12115
                s4o.print(")__uint_to_bcd(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12116
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12117
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12118
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12119
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12120
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12121
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12122
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12123
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12124
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12125
    }/*function_ulint_to_bcd*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12126
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12127
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12128
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12129
 *DATE_AND_TIME_TO_TIME_OF_DAY
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12130
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12131
    case function_date_and_time_to_time_of_day :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12132
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12133
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12134
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12135
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12136
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12137
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12138
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12139
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12140
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12141
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12142
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12143
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12144
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12145
                symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12146
                s4o.print("__date_and_time_to_time_of_day(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12147
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12148
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12149
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12150
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12151
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12152
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12153
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12154
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12155
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12156
    }/*function_date_and_time_to_time_of_day*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12157
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12158
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12159
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12160
 *DATE_AND_TIME_TO_DATE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12161
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12162
    case function_date_and_time_to_date :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12163
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12164
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12165
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12166
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12167
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12168
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12169
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12170
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12171
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12172
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12173
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12174
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12175
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12176
                symbol_c * return_type_symbol = &search_constant_type_c::date_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12177
                s4o.print("__date_and_time_to_date(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12178
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12179
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12180
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12181
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12182
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12183
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12184
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12185
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12186
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12187
    }/*function_date_and_time_to_date*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12188
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12189
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12190
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12191
 *ABS
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12192
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12193
    case function_abs :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12194
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12195
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12196
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12197
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12198
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12199
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12200
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12201
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12202
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12203
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12204
            if(search_expression_type->is_num_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12205
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12206
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12207
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12208
                s4o.print("__abs_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12209
                IN_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12210
                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12211
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12212
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12213
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12214
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12215
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12216
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12217
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12218
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12219
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12220
    }/*function_abs*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12221
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12222
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12223
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12224
 *SQRT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12225
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12226
    case function_sqrt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12227
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12228
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12229
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12230
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12231
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12232
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12233
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12234
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12235
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12236
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12237
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12238
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12239
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12240
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12241
                s4o.print("sqrt(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12242
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12243
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12244
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12245
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12246
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12247
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12248
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12249
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12250
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12251
    }/*function_sqrt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12252
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12253
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12254
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12255
 *LN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12256
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12257
    case function_ln :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12258
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12259
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12260
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12261
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12262
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12263
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12264
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12265
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12266
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12267
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12268
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12269
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12270
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12271
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12272
                s4o.print("ln(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12273
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12274
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12275
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12276
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12277
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12278
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12279
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12280
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12281
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12282
    }/*function_ln*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12283
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12284
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12285
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12286
 *LOG
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12287
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12288
    case function_log :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12289
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12290
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12291
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12292
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12293
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12294
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12295
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12296
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12297
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12298
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12299
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12300
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12301
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12302
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12303
                s4o.print("log(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12304
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12305
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12306
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12307
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12308
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12309
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12310
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12311
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12312
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12313
    }/*function_log*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12314
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12315
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12316
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12317
 *EXP
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12318
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12319
    case function_exp :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12320
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12321
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12322
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12323
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12324
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12325
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12326
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12327
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12328
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12329
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12330
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12331
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12333
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12334
                s4o.print("exp(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12335
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12336
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12337
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12338
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12339
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12340
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12341
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12342
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12343
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12344
    }/*function_exp*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12345
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12346
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12347
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12348
 *SIN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12349
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12350
    case function_sin :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12351
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12352
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12353
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12354
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12355
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12356
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12357
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12358
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12359
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12360
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12361
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12362
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12363
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12364
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12365
                s4o.print("sin(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12366
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12367
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12368
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12369
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12370
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12371
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12372
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12373
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12374
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12375
    }/*function_sin*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12376
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12377
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12378
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12379
 *COS
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12380
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12381
    case function_cos :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12382
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12383
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12384
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12385
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12386
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12387
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12388
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12389
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12390
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12391
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12392
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12393
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12394
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12395
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12396
                s4o.print("cos(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12397
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12398
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12399
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12400
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12401
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12402
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12403
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12404
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12405
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12406
    }/*function_cos*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12407
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12408
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12409
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12410
 *TAN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12411
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12412
    case function_tan :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12413
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12414
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12415
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12416
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12417
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12418
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12419
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12420
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12421
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12422
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12423
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12424
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12425
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12426
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12427
                s4o.print("tan(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12428
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12429
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12430
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12431
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12432
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12433
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12434
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12435
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12436
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12437
    }/*function_tan*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12438
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12439
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12440
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12441
 *ASIN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12442
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12443
    case function_asin :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12444
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12445
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12446
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12447
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12448
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12449
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12450
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12451
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12452
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12453
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12454
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12455
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12456
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12457
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12458
                s4o.print("asin(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12459
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12460
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12461
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12462
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12463
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12464
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12465
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12466
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12467
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12468
    }/*function_asin*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12469
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12470
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12471
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12472
 *ACOS
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12473
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12474
    case function_acos :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12475
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12476
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12477
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12478
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12479
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12480
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12481
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12482
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12483
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12484
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12485
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12486
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12487
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12488
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12489
                s4o.print("acos(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12490
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12491
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12492
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12493
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12494
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12495
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12496
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12497
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12498
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12499
    }/*function_acos*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12500
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12501
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12502
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12503
 *ATAN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12504
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12505
    case function_atan :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12506
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12507
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12508
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12509
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12510
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12511
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12512
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12513
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12514
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12515
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12516
            if(search_expression_type->is_real_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12517
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12518
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12519
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12520
                s4o.print("atan(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12521
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12522
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12523
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12524
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12525
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12526
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12527
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12528
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12529
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12530
    }/*function_atan*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12531
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12532
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12533
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12534
 *ADD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12535
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12536
    case function_add :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12537
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12538
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12539
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12540
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12541
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12542
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12543
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12544
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12545
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12546
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12547
            if(search_expression_type->is_num_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12548
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12549
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12550
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12551
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12552
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12553
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12554
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12555
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12556
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12557
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12558
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12559
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12560
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12561
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12562
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12563
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12564
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12565
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12566
                        s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12567
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12568
                        s4o.print("+\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12569
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12570
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12571
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12572
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12573
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12574
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12575
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12576
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12577
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12578
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12579
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12580
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12581
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12582
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12583
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12584
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12585
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12586
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12587
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12588
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12589
                                s4o.print("+\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12590
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12591
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12592
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12593
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12594
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12595
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12596
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12597
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12598
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12599
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12600
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12601
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12602
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12603
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12604
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12605
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12606
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12607
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12608
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12609
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12610
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12611
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12612
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12613
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12614
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12615
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12616
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12617
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12618
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12619
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12620
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12621
                    if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12622
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12623
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12624
                        symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12625
                        s4o.print("__time_add(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12626
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12627
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12628
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12629
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12630
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12631
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12632
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12633
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12634
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12635
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12636
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12637
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12638
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12639
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12640
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12641
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12642
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12643
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12644
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12645
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12646
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12647
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12648
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12649
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12650
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12651
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12652
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12653
                    if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12654
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12655
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12656
                        symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12657
                        s4o.print("__time_add(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12658
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12659
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12660
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12661
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12662
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12663
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12664
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12665
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12666
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12667
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12668
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12669
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12670
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12671
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12672
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12673
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12674
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12675
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12676
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12677
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12678
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12679
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12680
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12681
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12682
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12683
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12684
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12685
                    if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12686
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12687
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12688
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12689
                        s4o.print("__time_add(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12690
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12691
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12692
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12693
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12694
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12695
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12696
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12697
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12698
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12699
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12700
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12701
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12702
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12703
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12704
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12705
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12706
    }/*function_add*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12707
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12708
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12709
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12710
 *MUL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12711
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12712
    case function_mul :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12713
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12714
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12715
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12716
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12717
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12718
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12719
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12720
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12721
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12722
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12723
            if(search_expression_type->is_num_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12724
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12725
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12726
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12727
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12728
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12729
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12730
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12731
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12732
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12733
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12734
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12735
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12736
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12737
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12738
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12739
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12740
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12741
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12742
                        s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12743
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12744
                        s4o.print("*\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12745
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12746
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12747
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12748
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12749
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12750
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12751
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12752
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12753
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12754
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12755
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12756
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12757
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12758
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12759
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12760
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12761
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12762
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12763
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12764
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12765
                                s4o.print("*\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12766
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12767
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12768
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12769
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12770
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12771
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12772
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12773
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12774
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12775
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12776
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12777
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12778
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12779
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12780
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12781
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12782
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12783
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12784
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12785
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12786
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12787
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12788
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12789
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12790
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12791
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12792
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12793
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12794
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12795
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12796
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12797
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12798
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12799
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12800
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12801
                        s4o.print("__time_mul(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12802
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12803
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12804
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12805
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12806
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12807
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12808
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12809
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12810
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12811
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12812
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12813
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12814
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12815
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12816
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12817
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12818
    }/*function_mul*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12819
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12820
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12821
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12822
 *SUB
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12823
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12824
    case function_sub :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12825
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12826
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12827
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12828
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12829
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12830
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12831
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12832
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12833
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12834
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12835
            if(search_expression_type->is_num_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12836
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12837
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12838
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12839
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12840
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12841
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12842
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12843
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12844
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12845
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12846
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12847
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12848
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12849
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12850
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12851
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12852
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12853
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12854
                        s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12855
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12856
                        s4o.print("-\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12857
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12858
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12859
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12860
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12861
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12862
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12863
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12864
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12865
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12866
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12867
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12868
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12869
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12870
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12871
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12872
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12873
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12874
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12875
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12876
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12877
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12878
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12879
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12880
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12881
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12882
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12883
                    if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12884
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12885
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12886
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12887
                        s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12888
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12889
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12890
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12891
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12892
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12893
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12894
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12895
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12896
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12897
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12898
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12899
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12900
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12901
            if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12902
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12903
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12904
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12905
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12906
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12907
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12908
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12909
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12910
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12911
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12912
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12913
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12914
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12915
                    if(search_expression_type->is_same_type(&search_constant_type_c::dt_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12916
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12917
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12918
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12919
                        s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12920
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12921
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12922
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12923
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12924
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12925
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12926
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12927
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12928
                    if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12929
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12930
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12931
                        symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12932
                        s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12933
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12934
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12935
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12936
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12937
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12938
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12939
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12940
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12941
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12942
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12943
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12944
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12945
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12946
            if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12947
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12948
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12949
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12950
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12951
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12952
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12953
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12954
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12955
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12956
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12957
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12958
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12959
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12960
                    if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12961
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12962
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12963
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12964
                        s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12965
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12966
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12967
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12968
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12969
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12970
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12971
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12972
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12973
                    if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12974
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12975
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12976
                        symbol_c * return_type_symbol = &search_constant_type_c::tod_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12977
                        s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12978
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12979
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12980
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12981
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12982
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12983
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12984
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12985
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12986
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12987
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12988
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12989
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12990
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12991
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12992
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12993
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12994
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12995
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12996
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12997
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12998
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 12999
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13000
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13001
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13002
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13003
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13004
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13005
                    if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13006
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13007
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13008
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13009
                        s4o.print("__time_sub(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13010
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13011
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13012
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13013
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13014
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13015
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13016
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13017
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13018
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13019
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13020
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13021
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13022
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13023
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13024
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13025
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13026
    }/*function_sub*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13027
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13028
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13029
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13030
 *DIV
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13031
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13032
    case function_div :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13033
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13034
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13035
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13036
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13037
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13038
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13039
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13040
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13041
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13042
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13043
            if(search_expression_type->is_num_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13044
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13045
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13046
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13047
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13048
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13049
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13050
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13051
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13052
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13053
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13054
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13055
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13056
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13057
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13058
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13059
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13060
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13061
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13062
                        s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13063
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13064
                        s4o.print("/\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13065
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13066
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13067
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13068
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13069
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13070
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13071
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13072
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13073
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13074
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13075
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13076
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13077
            if(search_expression_type->is_same_type(&search_constant_type_c::time_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13078
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13079
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13080
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13081
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13082
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13083
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13084
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13085
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13086
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13087
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13088
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13089
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13090
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13091
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13092
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13093
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13094
                        symbol_c * return_type_symbol = &search_constant_type_c::time_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13095
                        s4o.print("__time_div(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13096
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13097
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13098
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13099
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13100
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13101
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13102
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13103
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13104
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13105
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13106
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13107
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13108
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13109
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13110
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13111
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13112
    }/*function_div*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13113
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13114
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13115
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13116
 *MOD
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13117
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13118
    case function_mod :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13119
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13120
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13121
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13122
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13123
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13124
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13125
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13126
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13127
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13128
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13129
            if(search_expression_type->is_num_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13130
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13131
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13132
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13133
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13134
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13135
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13136
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13137
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13138
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13139
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13140
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13141
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13142
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13143
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13144
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13145
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13146
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13147
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13148
                        s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13149
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13150
                        s4o.print("%\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13151
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13152
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13153
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13154
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13155
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13156
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13157
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13158
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13159
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13160
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13161
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13162
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13163
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13164
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13165
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13166
    }/*function_mod*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13167
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13168
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13169
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13170
 *EXPT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13171
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13172
    case function_expt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13173
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13174
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13175
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13176
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13177
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13178
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13179
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13180
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13181
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13182
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13183
            if(search_expression_type->is_num_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13184
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13185
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13186
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13187
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13188
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13189
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13190
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13191
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13192
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13193
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13194
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13195
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13196
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13197
                    if(search_expression_type->is_num_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13198
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13199
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13200
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13201
                        s4o.print("pow(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13202
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13203
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13204
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13205
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13206
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13207
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13208
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13209
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13210
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13211
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13212
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13213
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13214
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13215
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13216
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13217
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13218
    }/*function_expt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13219
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13220
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13221
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13222
 *MOVE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13223
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13224
    case function_move :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13225
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13226
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13227
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13228
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13229
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13230
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13231
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13232
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13233
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13234
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13235
            if(search_expression_type->is_num_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13236
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13237
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13238
                symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13239
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13240
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13241
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13242
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13243
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13244
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13245
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13246
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13247
    }/*function_move*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13248
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13249
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13250
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13251
 *SHL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13252
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13253
    case function_shl :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13254
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13255
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13256
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13257
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13258
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13259
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13260
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13261
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13262
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13263
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13264
            if(search_expression_type->is_binary_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13265
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13266
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13267
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13268
                    identifier_c param_name("N");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13269
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13270
                    symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13271
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13272
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13273
                    if (N_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13274
                      N_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13275
                    symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13276
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(N_type_symbol, last_type_symbol) ? search_expression_type->common_type(N_type_symbol, last_type_symbol) : N_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13277
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13278
                    if(search_expression_type->is_integer_type(N_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13279
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13280
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13281
                        symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13282
                        IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13283
                        s4o.print("<<");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13284
                        N_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13285
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13286
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13287
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13288
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13289
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13290
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13291
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13292
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13293
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13294
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13295
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13296
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13297
    }/*function_shl*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13298
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13299
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13300
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13301
 *SHR
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13302
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13303
    case function_shr :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13304
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13305
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13306
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13307
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13308
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13309
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13310
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13311
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13312
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13313
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13314
            if(search_expression_type->is_binary_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13315
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13316
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13317
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13318
                    identifier_c param_name("N");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13319
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13320
                    symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13321
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13322
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13323
                    if (N_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13324
                      N_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13325
                    symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13326
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(N_type_symbol, last_type_symbol) ? search_expression_type->common_type(N_type_symbol, last_type_symbol) : N_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13327
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13328
                    if(search_expression_type->is_integer_type(N_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13329
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13330
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13331
                        symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13332
                        IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13333
                        s4o.print(">>");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13334
                        N_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13335
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13336
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13337
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13338
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13339
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13340
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13341
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13342
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13343
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13344
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13345
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13346
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13347
    }/*function_shr*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13348
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13349
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13350
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13351
 *ROR
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13352
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13353
    case function_ror :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13354
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13355
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13356
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13357
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13358
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13359
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13360
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13361
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13362
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13363
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13364
            if(search_expression_type->is_nbinary_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13365
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13366
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13367
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13368
                    identifier_c param_name("N");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13369
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13370
                    symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13371
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13372
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13373
                    if (N_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13374
                      N_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13375
                    symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13376
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(N_type_symbol, last_type_symbol) ? search_expression_type->common_type(N_type_symbol, last_type_symbol) : N_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13377
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13378
                    if(search_expression_type->is_integer_type(N_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13379
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13380
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13381
                        symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13382
                        s4o.print("__ror_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13383
                        IN_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13384
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13385
                        IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13386
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13387
                        N_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13388
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13389
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13390
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13391
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13392
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13393
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13394
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13395
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13396
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13397
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13398
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13399
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13400
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13401
    }/*function_ror*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13402
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13403
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13404
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13405
 *ROL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13406
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13407
    case function_rol :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13408
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13409
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13410
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13411
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13412
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13413
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13414
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13415
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13416
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13417
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13418
            if(search_expression_type->is_nbinary_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13419
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13420
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13421
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13422
                    identifier_c param_name("N");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13423
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13424
                    symbol_c *N_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13425
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13426
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13427
                    if (N_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13428
                      N_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13429
                    symbol_c *N_type_symbol = search_expression_type->get_type(N_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13430
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(N_type_symbol, last_type_symbol) ? search_expression_type->common_type(N_type_symbol, last_type_symbol) : N_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13431
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13432
                    if(search_expression_type->is_integer_type(N_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13433
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13434
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13435
                        symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13436
                        s4o.print("__rol_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13437
                        IN_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13438
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13439
                        IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13440
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13441
                        N_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13442
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13443
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13444
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13445
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13446
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13447
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13448
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13449
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13450
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13451
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13452
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13453
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13454
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13455
    }/*function_rol*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13456
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13457
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13458
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13459
 *AND
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13460
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13461
    case function_and :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13462
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13463
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13464
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13465
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13466
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13467
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13468
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13469
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13470
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13471
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13472
            if(search_expression_type->is_binary_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13473
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13474
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13475
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13476
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13477
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13478
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13479
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13480
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13481
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13482
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13483
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13484
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13485
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13486
                    if(search_expression_type->is_binary_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13487
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13488
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13489
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13490
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13491
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13492
                        if (search_expression_type->is_bool_type(last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13493
                          s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13494
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13495
                        s4o.print("&\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13496
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13497
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13498
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13499
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13500
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13501
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13502
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13503
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13504
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13505
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13506
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13507
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13508
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13509
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13510
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13511
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13512
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13513
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13514
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13515
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13516
                                s4o.print("&\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13517
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13518
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13519
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13520
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13521
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13522
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13523
                        if (search_expression_type->is_bool_type(last_type_symbol)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13524
                          s4o.print("&1");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13525
                          s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13526
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13527
                        s4o.print("");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13528
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13529
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13530
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13531
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13532
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13533
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13534
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13535
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13536
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13537
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13538
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13539
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13540
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13541
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13542
    }/*function_and*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13543
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13544
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13545
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13546
 *OR
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13547
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13548
    case function_or :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13549
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13550
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13551
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13552
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13553
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13554
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13555
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13556
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13557
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13558
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13559
            if(search_expression_type->is_binary_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13560
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13561
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13562
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13563
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13564
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13565
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13566
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13567
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13568
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13569
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13570
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13571
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13572
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13573
                    if(search_expression_type->is_binary_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13574
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13575
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13576
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13577
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13578
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13579
                        if (search_expression_type->is_bool_type(last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13580
                          s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13581
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13582
                        s4o.print("|\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13583
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13584
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13585
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13586
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13587
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13588
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13589
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13590
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13591
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13592
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13593
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13594
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13595
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13596
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13597
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13598
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13599
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13600
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13601
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13602
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13603
                                s4o.print("|\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13604
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13605
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13606
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13607
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13608
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13609
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13610
                        if (search_expression_type->is_bool_type(last_type_symbol)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13611
                          s4o.print("&1");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13612
                          s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13613
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13614
                        s4o.print("");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13615
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13616
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13617
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13618
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13619
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13620
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13621
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13622
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13623
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13624
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13625
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13626
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13627
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13628
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13629
    }/*function_or*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13630
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13631
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13632
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13633
 *XOR
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13634
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13635
    case function_xor :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13636
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13637
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13638
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13639
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13640
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13641
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13642
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13643
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13644
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13645
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13646
            if(search_expression_type->is_binary_type(IN1_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13647
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13648
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13649
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13650
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13651
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13652
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13653
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13654
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13655
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13656
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13657
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13658
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13659
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13660
                    if(search_expression_type->is_binary_type(IN2_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13661
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13662
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13663
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13664
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13665
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13666
                        if (search_expression_type->is_bool_type(last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13667
                          s4o.print("(\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13668
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13669
                        s4o.print("^\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13670
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13671
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13672
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13673
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13674
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13675
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13676
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13677
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13678
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13679
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13680
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13681
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13682
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13683
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13684
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13685
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13686
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13687
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13688
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13689
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13690
                                s4o.print("^\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13691
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13692
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13693
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13694
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13695
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13696
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13697
                        if (search_expression_type->is_bool_type(last_type_symbol)) {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13698
                          s4o.print("&1");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13699
                          s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13700
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13701
                        s4o.print("");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13702
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13703
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13704
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13705
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13706
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13707
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13708
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13709
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13710
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13711
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13712
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13713
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13714
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13715
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13716
    }/*function_xor*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13717
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13718
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13719
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13720
 *NOT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13721
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13722
    case function_not :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13723
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13724
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13725
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13726
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13727
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13728
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13729
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13730
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13731
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13732
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13733
            if(search_expression_type->is_binary_type(IN_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13734
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13735
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13736
                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13737
                s4o.print("~");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13738
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13739
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13740
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13741
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13742
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13743
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13744
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13745
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13746
    }/*function_not*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13747
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13748
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13749
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13750
 *SEL
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13751
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13752
    case function_sel :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13753
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13754
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13755
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13756
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13757
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13758
            symbol_c *G_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13759
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13760
            symbol_c *G_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13761
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13762
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13763
            if(search_expression_type->is_same_type(&search_constant_type_c::bool_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13764
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13765
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13766
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13767
                    identifier_c param_name("IN0");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13768
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13769
                    symbol_c *IN0_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13770
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13771
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13772
                    if (IN0_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13773
                      IN0_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13774
                    symbol_c *IN0_type_symbol = search_expression_type->get_type(IN0_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13775
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN0_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN0_type_symbol, last_type_symbol) : IN0_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13776
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13777
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13778
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13779
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13780
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13781
                            identifier_c param_name("IN1");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13782
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13783
                            symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13784
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13785
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13786
                            if (IN1_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13787
                              IN1_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13788
                            symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13789
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN1_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN1_type_symbol, last_type_symbol) : IN1_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13790
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13791
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13792
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13793
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13794
                                symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13795
                                G_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13796
                                s4o.print(" ? ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13797
                                IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13798
                                s4o.print(" :  ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13799
                                IN0_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13800
                                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13801
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13802
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13803
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13804
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13805
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13806
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13807
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13808
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13809
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13810
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13811
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13812
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13813
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13814
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13815
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13816
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13817
    }/*function_sel*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13818
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13819
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13820
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13821
 *MAX
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13822
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13823
    case function_max :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13824
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13825
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13826
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13827
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13828
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13829
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13830
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13831
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13832
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13833
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13834
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13835
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13836
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13837
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13838
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13839
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13840
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13841
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13842
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13843
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13844
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13845
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13846
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13847
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13848
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13849
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13850
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13851
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13852
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13853
                        s4o.print("__max_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13854
                        return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13855
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13856
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13857
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13858
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13859
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13860
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13861
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13862
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13863
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13864
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13865
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13866
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13867
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13868
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13869
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13870
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13871
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13872
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13873
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13874
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13875
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13876
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13877
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13878
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13879
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13880
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13881
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13882
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13883
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13884
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13885
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13886
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13887
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13888
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13889
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13890
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13891
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13892
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13893
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13894
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13895
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13896
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13897
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13898
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13899
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13900
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13901
    }/*function_max*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13902
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13903
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13904
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13905
 *MIN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13906
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13907
    case function_min :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13908
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13909
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13910
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13911
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13912
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13913
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13914
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13915
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13916
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13917
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13918
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13919
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13920
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13921
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13922
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13923
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13924
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13925
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13926
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13927
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13928
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13929
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13930
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13931
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13932
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13933
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13934
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13935
                        symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13936
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13937
                        s4o.print("__min_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13938
                        return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13939
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13940
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13941
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13942
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13943
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13944
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13945
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13946
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13947
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13948
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13949
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13950
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13951
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13952
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13953
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13954
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13955
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13956
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13957
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13958
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13959
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13960
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13961
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13962
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13963
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13964
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13965
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13966
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13967
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13968
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13969
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13970
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13971
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13972
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13973
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13974
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13975
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13976
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13977
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13978
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13979
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13980
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13981
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13982
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13983
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13984
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13985
    }/*function_min*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13986
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13987
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13988
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13989
 *LIMIT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13990
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13991
    case function_limit :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13992
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13993
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13994
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13995
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13996
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13997
            symbol_c *MN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13998
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 13999
            symbol_c *MN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14000
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14001
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14002
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14003
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14004
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14005
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14006
                    identifier_c param_name("IN");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14007
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14008
                    symbol_c *IN_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14009
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14010
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14011
                    if (IN_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14012
                      IN_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14013
                    symbol_c *IN_type_symbol = search_expression_type->get_type(IN_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14014
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN_type_symbol, last_type_symbol) : IN_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14015
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14016
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14017
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14018
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14019
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14020
                            identifier_c param_name("MX");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14021
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14022
                            symbol_c *MX_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14023
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14024
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14025
                            if (MX_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14026
                              MX_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14027
                            symbol_c *MX_type_symbol = search_expression_type->get_type(MX_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14028
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(MX_type_symbol, last_type_symbol) ? search_expression_type->common_type(MX_type_symbol, last_type_symbol) : MX_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14029
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14030
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14031
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14032
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14033
                                symbol_c * return_type_symbol = IN_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14034
                                s4o.print("__limit_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14035
                                IN_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14036
                                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14037
                                MN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14038
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14039
                                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14040
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14041
                                MX_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14042
                                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14043
                                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14044
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14045
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14046
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14047
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14048
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14049
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14050
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14051
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14052
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14053
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14054
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14055
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14056
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14057
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14058
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14059
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14060
    }/*function_limit*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14061
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14062
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14063
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14064
 *MUX
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14065
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14066
    case function_mux :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14067
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14068
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14069
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14070
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14071
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14072
            symbol_c *K_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14073
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14074
            symbol_c *K_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14075
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14076
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14077
            if(search_expression_type->is_integer_type(K_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14078
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14079
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14080
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14081
                    identifier_c param_name("IN0");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14082
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14083
                    symbol_c *IN0_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14084
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14085
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14086
                    if (IN0_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14087
                      IN0_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14088
                    symbol_c *IN0_type_symbol = search_expression_type->get_type(IN0_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14089
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN0_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN0_type_symbol, last_type_symbol) : IN0_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14090
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14091
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14092
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14093
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14094
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14095
                            identifier_c param_name("IN1");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14096
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14097
                            symbol_c *IN1_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14098
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14099
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14100
                            if (IN1_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14101
                              IN1_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14102
                            symbol_c *IN1_type_symbol = search_expression_type->get_type(IN1_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14103
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN1_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN1_type_symbol, last_type_symbol) : IN1_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14104
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14105
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14106
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14107
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14108
                                symbol_c * return_type_symbol = last_type_symbol;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14109
                                s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14110
                                s4o.print("__mux_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14111
                                return_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14112
                                s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14113
                                s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14114
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14115
                                K_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14116
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14117
                                IN0_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14118
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14119
                                IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14120
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14121
                                int base_num = 2;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14122
                                symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14123
                                do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14124
                                    char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14125
                                    sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14126
                                    identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14127
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14128
                                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14129
                                    param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14130
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14131
                                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14132
                                    if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14133
                                      param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14134
                                    if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14135
                                        symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14136
                                        last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14137
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14138
                                        /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14139
                                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14140
                                        param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14141
                                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14142
                                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14143
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14144
                                }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14145
                                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14146
                                s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14147
                                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14148
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14149
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14150
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14151
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14152
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14153
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14154
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14155
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14156
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14157
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14158
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14159
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14160
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14161
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14162
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14163
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14164
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14165
    }/*function_mux*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14166
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14167
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14168
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14169
 *GT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14170
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14171
    case function_gt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14172
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14173
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14174
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14175
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14176
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14177
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14178
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14179
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14180
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14181
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14182
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14183
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14184
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14185
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14186
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14187
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14188
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14189
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14190
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14191
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14192
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14193
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14194
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14195
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14196
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14197
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14198
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14199
                        symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14200
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14201
                        s4o.print("__gt_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14202
                        last_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14203
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14204
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14205
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14206
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14207
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14208
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14209
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14210
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14211
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14212
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14213
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14214
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14215
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14216
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14217
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14218
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14219
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14220
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14221
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14222
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14223
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14224
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14225
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14226
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14227
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14228
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14229
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14230
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14231
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14232
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14233
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14234
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14235
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14236
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14237
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14238
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14239
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14240
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14241
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14242
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14243
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14244
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14245
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14246
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14247
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14248
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14249
    }/*function_gt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14250
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14251
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14252
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14253
 *GE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14254
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14255
    case function_ge :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14256
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14257
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14258
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14259
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14260
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14261
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14262
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14263
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14264
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14265
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14266
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14267
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14268
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14269
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14270
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14271
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14272
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14273
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14274
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14275
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14276
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14277
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14278
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14279
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14280
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14281
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14282
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14283
                        symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14284
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14285
                        s4o.print("__ge_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14286
                        last_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14287
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14288
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14289
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14290
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14291
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14292
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14293
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14294
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14295
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14296
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14297
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14298
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14299
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14300
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14301
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14302
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14303
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14304
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14305
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14306
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14307
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14308
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14309
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14310
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14311
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14312
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14313
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14314
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14315
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14316
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14317
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14318
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14319
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14320
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14321
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14322
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14323
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14324
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14325
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14326
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14327
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14328
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14329
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14330
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14331
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14332
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14333
    }/*function_ge*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14334
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14335
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14336
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14337
 *EQ
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14338
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14339
    case function_eq :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14340
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14341
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14342
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14343
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14344
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14345
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14346
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14347
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14348
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14349
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14350
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14351
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14352
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14353
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14354
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14355
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14356
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14357
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14358
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14359
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14360
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14361
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14362
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14363
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14364
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14365
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14366
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14367
                        symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14368
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14369
                        s4o.print("__eq_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14370
                        last_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14371
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14372
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14373
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14374
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14375
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14376
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14377
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14378
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14379
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14380
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14381
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14382
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14383
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14384
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14385
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14386
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14387
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14388
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14389
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14390
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14391
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14392
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14393
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14394
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14395
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14396
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14397
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14398
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14399
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14400
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14401
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14402
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14403
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14404
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14405
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14406
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14407
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14408
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14409
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14410
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14411
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14412
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14413
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14414
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14415
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14416
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14417
    }/*function_eq*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14418
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14419
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14420
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14421
 *LT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14422
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14423
    case function_lt :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14424
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14425
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14426
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14427
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14428
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14429
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14430
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14431
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14432
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14433
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14434
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14435
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14436
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14437
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14438
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14439
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14440
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14441
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14442
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14443
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14444
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14445
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14446
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14447
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14448
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14449
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14450
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14451
                        symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14452
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14453
                        s4o.print("__lt_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14454
                        last_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14455
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14456
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14457
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14458
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14459
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14460
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14461
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14462
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14463
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14464
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14465
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14466
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14467
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14468
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14469
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14470
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14471
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14472
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14473
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14474
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14475
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14476
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14477
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14478
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14479
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14480
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14481
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14482
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14483
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14484
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14485
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14486
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14487
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14488
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14489
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14490
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14491
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14492
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14493
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14494
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14495
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14496
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14497
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14498
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14499
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14500
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14501
    }/*function_lt*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14502
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14503
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14504
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14505
 *LE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14506
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14507
    case function_le :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14508
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14509
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14510
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14511
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14512
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14513
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14514
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14515
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14516
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14517
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14518
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14519
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14520
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14521
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14522
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14523
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14524
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14525
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14526
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14527
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14528
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14529
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14530
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14531
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14532
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14533
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14534
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14535
                        symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14536
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14537
                        s4o.print("__le_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14538
                        last_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14539
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14540
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14541
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14542
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14543
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14544
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14545
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14546
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14547
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14548
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14549
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14550
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14551
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14552
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14553
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14554
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14555
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14556
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14557
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14558
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14559
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14560
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14561
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14562
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14563
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14564
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14565
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14566
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14567
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14568
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14569
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14570
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14571
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14572
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14573
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14574
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14575
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14576
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14577
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14578
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14579
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14580
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14581
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14582
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14583
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14584
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14585
    }/*function_le*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14586
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14587
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14588
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14589
 *NE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14590
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14591
    case function_ne :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14592
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14593
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14594
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14595
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14596
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14597
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14598
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14599
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14600
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14601
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14602
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14603
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14604
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14605
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14606
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14607
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14608
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14609
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14610
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14611
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14612
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14613
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14614
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14615
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14616
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14617
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14618
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14619
                        symbol_c * return_type_symbol = &search_constant_type_c::bool_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14620
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14621
                        s4o.print("__ne_");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14622
                        last_type_symbol->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14623
                        s4o.print("(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14624
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14625
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14626
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14627
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14628
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14629
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14630
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14631
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14632
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14633
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14634
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14635
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14636
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14637
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14638
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14639
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14640
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14641
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14642
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14643
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14644
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14645
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14646
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14647
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14648
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14649
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14650
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14651
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14652
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14653
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14654
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14655
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14656
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14657
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14658
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14659
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14660
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14661
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14662
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14663
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14664
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14665
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14666
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14667
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14668
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14669
    }/*function_ne*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14670
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14671
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14672
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14673
 *LEN
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14674
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14675
    case function_len :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14676
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14677
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14678
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14679
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14680
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14681
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14682
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14683
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14684
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14685
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14686
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14687
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14688
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14689
                symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14690
                s4o.print("__len(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14691
                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14692
                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14693
                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14694
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14695
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14696
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14697
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14698
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14699
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14700
    }/*function_len*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14701
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14702
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14703
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14704
 *LEFT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14705
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14706
    case function_left :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14707
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14708
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14709
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14710
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14711
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14712
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14713
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14714
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14715
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14716
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14717
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14718
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14719
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14720
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14721
                    identifier_c param_name("L");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14722
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14723
                    symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14724
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14725
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14726
                    if (L_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14727
                      L_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14728
                    symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14729
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(L_type_symbol, last_type_symbol) ? search_expression_type->common_type(L_type_symbol, last_type_symbol) : L_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14730
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14731
                    if(search_expression_type->is_integer_type(L_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14732
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14733
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14734
                        symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14735
                        s4o.print("__left(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14736
                        IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14737
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14738
                        L_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14739
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14740
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14741
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14742
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14743
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14744
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14745
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14746
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14747
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14748
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14749
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14750
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14751
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14752
    }/*function_left*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14753
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14754
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14755
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14756
 *RIGHT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14757
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14758
    case function_right :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14759
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14760
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14761
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14762
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14763
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14764
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14765
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14766
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14767
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14768
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14769
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14770
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14771
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14772
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14773
                    identifier_c param_name("L");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14774
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14775
                    symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14776
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14777
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14778
                    if (L_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14779
                      L_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14780
                    symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14781
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(L_type_symbol, last_type_symbol) ? search_expression_type->common_type(L_type_symbol, last_type_symbol) : L_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14782
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14783
                    if(search_expression_type->is_integer_type(L_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14784
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14785
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14786
                        symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14787
                        s4o.print("__right(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14788
                        IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14789
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14790
                        L_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14791
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14792
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14793
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14794
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14795
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14796
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14797
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14798
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14799
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14800
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14801
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14802
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14803
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14804
    }/*function_right*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14805
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14806
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14807
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14808
 *MID
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14809
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14810
    case function_mid :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14811
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14812
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14813
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14814
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14815
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14816
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14817
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14818
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14819
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14820
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14821
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14822
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14823
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14824
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14825
                    identifier_c param_name("L");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14826
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14827
                    symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14828
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14829
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14830
                    if (L_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14831
                      L_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14832
                    symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14833
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(L_type_symbol, last_type_symbol) ? search_expression_type->common_type(L_type_symbol, last_type_symbol) : L_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14834
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14835
                    if(search_expression_type->is_integer_type(L_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14836
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14837
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14838
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14839
                            identifier_c param_name("P");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14840
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14841
                            symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14842
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14843
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14844
                            if (P_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14845
                              P_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14846
                            symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14847
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(P_type_symbol, last_type_symbol) ? search_expression_type->common_type(P_type_symbol, last_type_symbol) : P_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14848
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14849
                            if(search_expression_type->is_integer_type(P_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14850
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14851
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14852
                                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14853
                                s4o.print("__mid(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14854
                                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14855
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14856
                                L_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14857
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14858
                                P_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14859
                                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14860
                                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14861
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14862
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14863
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14864
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14865
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14866
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14867
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14868
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14869
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14870
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14871
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14872
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14873
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14874
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14875
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14876
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14877
    }/*function_mid*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14878
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14879
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14880
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14881
 *CONCAT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14882
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14883
    case function_concat :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14884
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14885
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14886
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14887
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14888
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14889
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14890
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14891
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14892
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14893
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14894
            if(search_expression_type->is_same_type(&search_constant_type_c::date_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14895
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14896
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14897
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14898
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14899
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14900
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14901
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14902
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14903
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14904
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14905
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14906
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14907
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14908
                    if(search_expression_type->is_same_type(&search_constant_type_c::tod_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14909
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14910
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14911
                        symbol_c * return_type_symbol = &search_constant_type_c::dt_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14912
                        s4o.print("__time_add(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14913
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14914
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14915
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14916
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14917
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14918
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14919
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14920
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14921
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14922
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14923
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14924
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14925
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14926
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14927
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14928
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14929
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14930
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14931
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14932
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14933
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14934
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14935
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14936
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14937
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14938
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14939
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14940
                    if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14941
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14942
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14943
                        symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14944
                        s4o.indent_right();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14945
                        s4o.print("__concat(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14946
                        s4o.print_integer(nb_param);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14947
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14948
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14949
                        s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14950
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14951
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14952
                        int base_num = 3;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14953
                        symbol_c *param_value = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14954
                        do{
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14955
                            char my_name[10];
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14956
                            sprintf(my_name, "IN%d", base_num++);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14957
                            identifier_c param_name(my_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14958
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14959
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14960
                            param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14961
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14962
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14963
                            if (param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14964
                              param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14965
                            if (param_value != NULL){
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14966
                                symbol_c *current_type_symbol = search_expression_type->get_type(param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14967
                                last_type_symbol = last_type_symbol && search_expression_type->is_same_type(current_type_symbol, last_type_symbol) ? search_expression_type->common_type(current_type_symbol, last_type_symbol) : current_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14968
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14969
                                /*Function specific CODE */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14970
                                s4o.print(",\n" + s4o.indent_spaces);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14971
                                param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14972
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14973
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14974
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14975
                        }while(param_value != NULL);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14976
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14977
                        s4o.indent_left();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14978
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14979
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14980
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14981
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14982
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14983
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14984
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14985
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14986
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14987
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14988
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14989
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14990
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14991
    }/*function_concat*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14992
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14993
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14994
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14995
 *INSERT
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14996
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14997
    case function_insert :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14998
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 14999
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15000
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15001
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15002
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15003
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15004
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15005
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15006
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15007
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15008
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15009
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15010
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15011
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15012
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15013
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15014
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15015
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15016
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15017
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15018
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15019
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15020
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15021
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15022
                    if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15023
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15024
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15025
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15026
                            identifier_c param_name("P");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15027
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15028
                            symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15029
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15030
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15031
                            if (P_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15032
                              P_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15033
                            symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15034
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(P_type_symbol, last_type_symbol) ? search_expression_type->common_type(P_type_symbol, last_type_symbol) : P_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15035
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15036
                            if(search_expression_type->is_integer_type(P_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15037
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15038
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15039
                                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15040
                                s4o.print("__insert(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15041
                                IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15042
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15043
                                IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15044
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15045
                                P_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15046
                                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15047
                                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15048
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15049
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15050
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15051
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15052
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15053
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15054
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15055
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15056
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15057
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15058
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15059
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15060
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15061
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15062
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15063
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15064
    }/*function_insert*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15065
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15066
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15067
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15068
 *DELETE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15069
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15070
    case function_delete :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15071
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15072
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15073
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15074
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15075
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15076
            symbol_c *IN_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15077
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15078
            symbol_c *IN_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15079
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15080
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15081
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15082
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15083
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15084
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15085
                    identifier_c param_name("L");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15086
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15087
                    symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15088
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15089
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15090
                    if (L_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15091
                      L_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15092
                    symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15093
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(L_type_symbol, last_type_symbol) ? search_expression_type->common_type(L_type_symbol, last_type_symbol) : L_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15094
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15095
                    if(search_expression_type->is_integer_type(L_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15096
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15097
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15098
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15099
                            identifier_c param_name("P");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15100
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15101
                            symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15102
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15103
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15104
                            if (P_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15105
                              P_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15106
                            symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15107
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(P_type_symbol, last_type_symbol) ? search_expression_type->common_type(P_type_symbol, last_type_symbol) : P_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15108
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15109
                            if(search_expression_type->is_integer_type(P_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15110
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15111
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15112
                                symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15113
                                s4o.print("__delete(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15114
                                IN_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15115
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15116
                                L_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15117
                                s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15118
                                P_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15119
                                s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15120
                                return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15121
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15122
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15123
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15124
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15125
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15126
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15127
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15128
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15129
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15130
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15131
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15132
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15133
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15134
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15135
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15136
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15137
    }/*function_delete*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15138
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15139
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15140
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15141
 *REPLACE
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15142
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15143
    case function_replace :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15144
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15145
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15146
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15147
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15148
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15149
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15150
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15151
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15152
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15153
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15154
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15155
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15156
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15157
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15158
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15159
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15160
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15161
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15162
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15163
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15164
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15165
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15166
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15167
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15168
                    if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15169
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15170
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15171
                        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15172
                            identifier_c param_name("L");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15173
                            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15174
                            symbol_c *L_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15175
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15176
                            /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15177
                            if (L_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15178
                              L_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15179
                            symbol_c *L_type_symbol = search_expression_type->get_type(L_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15180
                            last_type_symbol = last_type_symbol && search_expression_type->is_same_type(L_type_symbol, last_type_symbol) ? search_expression_type->common_type(L_type_symbol, last_type_symbol) : L_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15181
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15182
                            if(search_expression_type->is_integer_type(L_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15183
                            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15184
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15185
                                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15186
                                    identifier_c param_name("P");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15187
                                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15188
                                    symbol_c *P_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15189
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15190
                                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15191
                                    if (P_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15192
                                      P_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15193
                                    symbol_c *P_type_symbol = search_expression_type->get_type(P_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15194
                                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(P_type_symbol, last_type_symbol) ? search_expression_type->common_type(P_type_symbol, last_type_symbol) : P_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15195
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15196
                                    if(search_expression_type->is_integer_type(P_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15197
                                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15198
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15199
                                        symbol_c * return_type_symbol = &search_constant_type_c::string_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15200
                                        s4o.print("__replace(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15201
                                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15202
                                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15203
                                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15204
                                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15205
                                        L_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15206
                                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15207
                                        P_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15208
                                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15209
                                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15210
                                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15211
                                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15212
                                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15213
                                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15214
                                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15215
                                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15216
                            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15217
                            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15218
                            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15219
                        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15220
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15221
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15222
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15223
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15224
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15225
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15226
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15227
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15228
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15229
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15230
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15231
    }/*function_replace*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15232
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15233
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15234
/****
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15235
 *FIND
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15236
 */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15237
    case function_find :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15238
    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15239
        symbol_c *last_type_symbol = NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15240
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15241
        {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15242
            /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15243
            symbol_c *IN1_param_value = &this->default_variable_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15244
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15245
            symbol_c *IN1_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15246
            last_type_symbol = param_data_type;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15247
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15248
            if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15249
            {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15250
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15251
                {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15252
                    identifier_c param_name("IN2");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15253
                    /* Get the value from a foo(<param_name> = <param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15254
                    symbol_c *IN2_param_value = function_call_param_iterator.search(&param_name);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15255
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15256
                    /* Get the value from a foo(<param_value>) style call */
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15257
                    if (IN2_param_value == NULL)
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15258
                      IN2_param_value = function_call_param_iterator.next();
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15259
                    symbol_c *IN2_type_symbol = search_expression_type->get_type(IN2_param_value);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15260
                    last_type_symbol = last_type_symbol && search_expression_type->is_same_type(IN2_type_symbol, last_type_symbol) ? search_expression_type->common_type(IN2_type_symbol, last_type_symbol) : IN2_type_symbol ;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15261
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15262
                    if(search_expression_type->is_same_type(&search_constant_type_c::string_type_name, last_type_symbol))
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15263
                    {
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15264
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15265
                        symbol_c * return_type_symbol = &search_constant_type_c::int_type_name;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15266
                        s4o.print("__find(");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15267
                        IN1_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15268
                        s4o.print(", ");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15269
                        IN2_param_value->accept(*this);
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15270
                        s4o.print(")");
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15271
                        return NULL;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15272
                        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15273
                    }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15274
                    
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15275
                    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15276
                }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15277
                
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15278
            }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15279
            
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15280
            ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15281
        }
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15282
        
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15283
    }/*function_find*/
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15284
    break;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15285
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15286
    case function_none :
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15287
    ERROR;
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15288
}
e1f0ebd2d9ec Change generate_cc to generate_c
lbessard
parents:
diff changeset
 15289
return NULL;